# DATABOUK Z8500 UNIVERSAL PERIPHERALS 1°T EDITION



BELL INDUSTRIES Electronics Distributor Division 1161 N. Fairoaks Avenue Sunnyvale, California 94086 (408) 734-8570 TWX NO. 910-339-9378

## Z8500 UNIVERSAL PERPHERALS ISSUED JANUARY 1983

## CONTENTS

|           | Page      |
|-----------|-----------|
| Z8530 SCC | 3 - 30    |
| Z8536 CIO | 31 - 64   |
| Z8538 FIO | 65 - 101  |
| Z8590 UPC | 103 - 129 |

## **Z8500** Universal Peripherals

SGS' Universal Peripheral Components Family is more than a group of simple I/O circuits—they are intelligent, fully programmable devices capable of performing complicated tasks independently. Their capabilities unburden the master CPU, reduce bus traffic, increase system throughput, and greatly simplify overall system hardware design requirements.

Z8500 series Universal Peripheral components are capable of interfacing with conventional non-multiplexed buses. All of them are extensively programmable to permit each to be tailored to its own applications. Also available is a series of functionally similar devices, identified by the number Z80xx, which interface with the Z-BUS<sup>TM</sup> or both the Z-BUS and conventional multiplexed buses.

Data communications problems are neatly handled by the Z8530 SCC Serial

**Communications Controller**. This device is a serial, dual-channel, multi-protocol controller which supports all popular communications formats. The SCC support virtually all serial data transfer applications.

Counting, timing, and parallel I/O transfer problems are easily solved using the **Z8536 CIO Counter/Timer and I/O Unit**. This components has three 16-bit counter/timers, three I/O ports, and can double as a programmable priority-interrupt controller.

Interface problems with the interconnections of major components within an asynchronous, parallel processor system can be solved using the SCC **Z8538 FIO FIFO I/O Interface Unit**. This generalpurpose interface unit provides expandable, bidirectional buffering between asynchronous CPUs in a parallel processing network, or between a CPU and peripheral circuits and/or devices. The FIO can be used with system having either multiplexed or nonmultiplexed buses.

General-purpose control and data manipulation problems are easily handled by the **Z8590 UCP Universal Peripheral Controller**. The UPC is a complete microcomputer designed for offline applications. This microcomputer executes the same friendly capable instruction set as SGS' Z8<sup>TM</sup> microcomputer; it has three I/O ports, six levels of priority-interrupt, and 2K bytes of memory on chip. The UPC is intended for applications that require an intelligent peripheral controller which can assume many of the tasks normally required of the master CPU.

Ì 

### Serial Communications Controller



#### Features

- Two independent, 0 to 1M bit/second, fullduplex channels, each with a separate crystal oscillator, baud rate generator, and Digital Phase-Locked Loop for clock recovery.
- Multi-protocol operation under program control; programmable for NRZ, NRZI, or FM data encoding.
- Asynchronous mode with five to eight bits and one, one and one-half, or two stop bits per character; programmable clock factor; break detection and generation; parity, overrun, and framing error detection.
- **General Description**

The Z8530 SCC Serial Communications Controller is a dual-channel, multi-protocol data communications peripheral designed for use with conventional non-multiplexed buses. The SCC functions as a serial-to-parallel, parallel-to-serial converter/controller. The SCC can be software-configured to satisfy a

- Synchronous mode with internal or external character synchronization on one or two synchronous characters and CRC generation and checking with CRC-16 or CRC-CCITT preset to either 1s or 0s.
- SDLC/HDLC mode with comprehensive frame-level control, automatic zero insertion and deletion, I-field residue handling, abort generation and detection, CRC generation and checking, and SDLC Loop mode operation.
- Local Loopback and Auto Echo modes.

wide variety of serial communications applications. The device contains a variety of new, sophisticated internal functions including on-chip baud rate generators, Digital Phase-Locked Loops, and crystal oscillators that dramatically reduce the need for external logic.



3



#### General Description (Continued)

The SCC handles asynchronous formats, Synchronous byte-oriented protocols such as IBM Bisync, and Synchronous bit-oriented protocols such as HDLC and IBM SDLC. This versatile device supports virtually any serial data transfer application (cassette, diskette, tape drives, etc.).

The device can generate and check CRC codes in any Synchronous mode and can be programmed to check data integrity in various modes. The SCC also has facilities for

#### **Pin Description**

The following section describes the pin functions of the SCC. Figures 1 and 2 detail the respective pin functions and pin assignments.

 $\mathbf{A}/\mathbf{B}$ . Channel A/Channel B Select (input). This signal selects the channel in which the read or write operation occurs.

**CE.** Chip Enable (input, active Low). This signal selects the SCC for a read or write operation.

**CTSA. CTSB.** Clear To Send (inputs, active Low). If these pins are programmed as Auto Enables, a Low on the inputs enables the respective transmitters. If not programmed as Auto Enables, they may be used as general-purpose inputs. Both inputs are Schmitt-trigger buffered to accommodate slow rise-time inputs. The SCC detects pulses on these inputs and can interrupt the CPU on both logic level transitions.

**D/C.** Data/Control Select (input). This signal defines the type of information transferred to or from the SCC. A High means data is transferred; a Low indicates a command.

**DCDA**, **DCDB**. Data Carrier Detect (inputs, active Low). These pins function as receiver enables if they are programmed for Auto Enables; otherwise they may be used as general-purpose input pins. Both pins are Schmitt-trigger buffered to accomodate slow rise-time signals. The SCC detects pulses on

modem controls in both channels. In applications where these controls are not needed, the modem controls can be used for general-purpose I/O.

The Z-BUS daisy-chain interrupt hierarchy is also supported — as is standard for SGS peripheral components.

The Z8530 SCC is packaged in a 40-pin ceramic DIP and uses a single +5 V power supply.

these pins and can interrupt the CPU on both logic level transitions.

**D**<sub>0</sub>-**D**<sub>7</sub>. Data Bus (bidirectional, 3-state). These lines carry data and commands to and from the SCC.

**DTR/REQA**, **DTR/REQB**. Data Terminal Ready/Request (outputs, active Low). These outputs follow the state programmed into the DTR bit. They can also be used as generalpurpose outputs or as Request lines for a DMA controller.

**IEI.** Interrupt Enable In (input, active High). IEI is used with IEO to form an interrupt daisy chain when there is more than one interruptdriven device. A High IEI indicates that no other higher priority device has an interrupt under service or is requesting an interrupt.

**IEO.** Interrupt Enable Out (output, active High). IEO is High only if IEI is High and the CPU is not servicing an SCC interrupt or the SCC is not requesting an interrupt (Interrupt Acknowledge cycle only). IEO is connected to the next lower priority device's IEI input and thus inhibits interrupts from lower priority devices.

**INT.** Interrupt Request (output, open-drain, active Low). This signal is activated when the SCC requests an interrupt.

**INTACK.** Interrupt Acknowledge (input, active Low). This signal indicates an active Interrupt Acknowledge cycle. During this cycle, the

#### Pin Description (Continued)

SCC interrupt daisy chain settles. When RD becomes active, the SCC places an interrupt <u>vector on</u> the data bus (if IEI is High). <u>INTACK</u> is latched by the rising edge of PCLK.

**PCLK.** *Clock* (input). This is the master SCC clock used to synchronize internal signals PCLK is a TTL level signal.

**RD.** *Read* (input, active Low). This signal indicates a read operation and when the SCC is selected, enables the SCC's bus drivers. During the Interrupt Acknowledge cycle, this signal gates the interrupt vector onto the bus if the SCC is the highest priority device requesting an interrupt.

**RxDA, RxDB.** *Receive Data* (inputs, active High). These input signals receive serial data at standard TTL levels.

**RTxCA**, **RTxCB**. Receive/Transmit Clocks (inputs, active Low). These pins can be programmed in several different modes of operation. In each channel,  $\overline{\text{RTxC}}$  may supply the receive clock, the transmit clock, the clock for the baud rate generator, or the clock for the Digital Phase-Locked Loop. These pins can also <u>be programmed</u> for use with the respective SYNC pins as a crystal oscillator. The receive clock may be 1, 16, 32, or 64 times the data rate in Asynchronous modes.

**RTSA**, **RTSB**. Request To Send (outputs, active Low). When the Request To Send (RTS) bit in Write Register 5 (Figure 11) is set, the RTS signal goes Low. When the RTS bit is reset in the Asynchronous mode and Auto Enable is on, the signal goes High after the transmitter is empty. In Synchronous mode or in Asynchronous mode with Auto Enable off, the RTS pin strictly follows the state of the RTS bit. Both pins can be used as general-purpose outputs.

**SYNCA. SYNCB.** Synchronization (inputs or outputs, active Low). These pins can act either as inputs, outputs, or part of the crystal oscillator circuit. In the Asynchronous Receive mode (crystal oscillator option not selected), these pins are inputs similar to CTS and DCD. In this mode, transitions on these lines affect

the state of the Synchronous/Hunt status bits in Read Register 0 (Figure 10) but have no other function.

78530 SCC

In External Synchronization mode with the crystal oscillator not selected, these lines also act as inputs. In this mode,  $\overline{\text{SYNC}}$  must be driven Low two receive clock cycles after the last bit in the synchronous character is received. Character assembly begins on the rising edge of the receive clock immediately preceding the activation of  $\overline{\text{SYNC}}$ .

In the Internal Synchronization mode (Monosync and Bisync) with the crystal oscillator not selected, these pins act as outputs and are active only during the part of the receive clock cycle in which synchronous characters are recognized. The synchronous condition is not latched, so these outputs are active each time a synchronization pattern is recognized (regardless of character boundaries). In SDLC mode, these pins act as outputs and are valid on receipt of a flag.

**TxDB.** *TxDB. Transmit Data* (outputs, active High). These output signals transmit serial data at standard TTL levels.

**TRxCA**, **TRxCB**. Transmit/Receive Clocks (inputs or outputs, active Low). These pins can be programmed in several different modes of operation. TRxC may supply the receive clock or the transmit clock in the input mode or supply the output of the Digital Phase-Locked Loop, the crystal oscillator, the baud rate generator, or the transmit clock in the output mode.

**WR.** Write (input, active Low). When the SCC is selected, this signal indicates a write operation. The coincidence of  $\overline{RD}$  and  $\overline{WR}$  is interpreted as a reset.

**W/REQA, W/REQB.** Wait/Request (outputs, open-drain when programmed for a Wait function, driven High or Low when programmed for a Request function). These dual-purpose outputs may be programmed as Request lines for a DMA controller or as Wait lines to synchronize the CPU to the SCC data rate. The reset state is Wait.



#### **Functional Description**

The functional capabilities of the SCC can be described from two different points of view: as a data communications device, it transmits and receives data in a wide variety of data communications protocols; as a microprocessor peripheral, the SCC offers valuable features such as vectored interrupts, polling, and simple handshake capability.

**Data Communications Capabilities.** The SCC provides two independent full-duplex channels programmable for use in any common Asynchronous or Synchronous data-communication protocol. Figure 3 and the following description briefly detail these protocols.

Asynchronous Modes. Transmission and reception can be accomplished independently on each channel with five to eight bits per character, plus optional even or odd parity. The transmitters can supply one, one-and-ahalf, or two stop bits per character and can provide a break output at any time. The receiver break-detection logic interrupts the CPU both at the start and at the end of a received break. Reception is protected from spikes by a transient spike-rejection mechanism that checks the signal one-half a bit time after a Low level is detected on the receive data input (RxDA or RxDB in Figure 1). If the Low does not persist (as in the case of a transient), the character assembly process does not start.

Framing errors and overrun errors are detected and buffered together with the partial character on which they occur. Vectored interrupts allow fast servicing or error conditions using dedicated routines. Furthermore, a built-in checking process avoids the interpretation of a framing error as a new start bit: a framing error results in the addition of one-half a bit time to the point at which the search for the next start bit begins.

The SCC does not require symmetric transmit and receive clock signals—a feature allowing use of the wide variety of clock sources. The transmitter and receiver can handle data at a rate of 1, 1/16, 1/32, or 1/64 of the clock rate supplied to the receive and transmit clock inputs. In Asynchronous modes, the SYNC pin may be programmed as an input used for functions such as monitoring a ring indicator.

Synchronous Modes. The SCC supports both byte-oriented and bit-oriented synchronous communication. Synchronous byte-oriented protocols can be handled in several modes,





## **STS** 28530 SCC

#### Functional Description (Continued)

allowing character synchronization with a 6-bit or 8-bit synchronous character (Monosync), any 12-bit synchronization pattern (Bisync), or with an external synchronous signal. Leading sync characters can be removed without interrupting the CPU.

Five- or 7-bit synchronous characters are detected with 8- or 16-bit patterns in the SCC by overlapping the larger pattern across multiple incoming synchronous characters as shown in Figure 4.

CRC checking for Synchronous byteoriented modes is delayed by one character time so that the CPU may disable CRC checking on specific characters. This permits the implementation of protocols such as IBM Bisync.

Both CRC-16 (X<sup>16</sup> + X<sup>15</sup> + X<sup>2</sup> + 1) and CCITT  $(X^{16} + X^{12} + X^5 + 1)$  error checking polynomials are supported. Either polynomial may be selected in all Synchronous modes. Users may preset the CRC generator and checker to all 1s or all 0s. The SCC also provides a feature that automatically transmits CRC data when no other data is available for transmission. This allows for high speed transmissions under DMA control, with no need for CPU intervention at the end of a message. When there is no data or CRC to send in Synchronous modes, the transmitter inserts 6-, 8-, or 16-bit synchronous characters, regardless of the programmed character length.

The SCC supports Synchronous bit-oriented protocols, such as SDLC and HDLC, by performing automatic flag sending, zero insertion, and CRC generation. A special command can be used to abort a frame in transmission. At the end of a message, the SCC automatically transmits the CRC and trailing flag when the transmitter underruns. The transmitter may also be programmed to send an idle line consisting of continuous flag characters or a steady marking condition.

If a transmit underrun occurs in the middle of a message, an external/status interrupt warns the CPU of this status change so that an abort may be issued. The SCC may also be programmed to send an abort itself in case of an underrun, relieving the CPU of this task. One to eight bits per character can be sent, allowing reception of a message with no prior information about the character structure in the information field of a frame.

The receiver automatically acquires synchronization on the leading flag of a frame in SDLC or HDLC and provides a synchronization signal on the SYNC pin (an interrupt can also be programmed). The receiver can be programmed to search for frames addressed by a single byte (or four bits within a byte) of a user-selected address or to a global broadcast address. In this mode, frames not matching either the user-selected or broadcast address are ignored. The number of address bytes can be extended under software control. For receiving data, an interrupt on the first received character, or an interrupt on every character, or on special condition only (endof-frame) can be selected. The receiver automatically deletes all 0s inserted by the transmitter during character assembly. CRC is also calculated and is automatically checked to validate frame transmission. At the end of transmission, the status of a received frame is available in the status registers. In SDLC mode, the SCC must be programmed to use the SDLC CRC polynomial, but the generator and checker may be preset to all 1s or all 0s. The CRC is inverted before transmission and the receiver checks against the bit pattern 0001110100001111.



#### Figure 4. Detecting 5 - or 7 - Bit Synchronous Characters

7



NRZ, NRZI or FM coding may be used in any lx mode. The parity options available in Asynchronous modes are available in Synchronous modes.

The SCC can be conveniently used under DMA control to provide high speed reception or transmission. In reception, for example, the SCC can interrupt the CPU when the first character of a message is received. The CPU then enables the DMA to transfer the message to memory. The SCC then issues an end-offrame interrupt and the CPU can check the status of the received message. Thus, the CPU is freed for other service while the message is being received. The CPU may also enable the DMA first and have the SCC interrupt only on end-of-frame. This procedure allows all data to be transferred via the DMA.

**SDLC Loop Mode.** The SCC supports SDLC Loop mode in addition to normal SDLC. In an SDLC Loop, there is a primary controller station that manages the message traffic flow on the loop and any number of secondary stations. In SDLC Loop mode, the SCC performs the functions of a secondary station while an SCC operating in regular SDLC mode can act as a controller (Figure 5).

A secondary station in an SDLC Loop is always listening to the messages being sent around the loop, and in fact must pass these messages to the rest of the loop by retransmitting them with a one-bit-time delay. The secondary station can place its own message



Figure 5. An SDLC Loop

on the loop only at specific times. The controller signals that secondary stations may transmit messages by sending a special character, called an EOP (End Of Poll), around the loop. The EOP character is the bit pattern 1111110. Because of zero insertion during messages, this bit pattern is unique and easily recognized.

When a secondary station has a message to transmit and recognizes an EOP on the line, it changes the last binary 1 of the EOP to a 0 before transmission. This has the effect of turning the EOP into a flag sequence. The secondary station now places its message on the loop and terminates the message with an EOP. Any secondary stations further down the loop with messages to transmit can then append their messages to the message of the first secondary station by the same process. Any secondary stations without messages to send merely echo the incoming messages and are prohibited from placing messages on the loop (except upon recognizing an EOP).

SDLC Loop mode is a programmable option in the SCC. NRZ, NRZI, and FM coding may all be used in SDLC Loop mode.

Baud Rate Generator. Each channel in the SCC contains a programmable baud rate generator. Each generator consists of two 8-bit time constant registers that form a 16-bit time constant, a 16-bit down counter, and a flip-flop on the output producing a square wave. On startup, the flip-flop on the output is set in a High state, the value in the time constant register is loaded into the counter, and the counter starts counting down. The output of the baud rate generator toggles upon reaching 0, the value in the time constant register is loaded into the counter, and the process is repeated. The time constant may be changed at any time, but the new value does not take effect until the next load of the counter.

The output of the baud rate generator may be used as either the transmit clock, the receive clock, or both. It can also drive the Digital Phase-Locked Loop (see next section).

If the receive clock or transmit clock is not programmed to come from the TRxC pin, the



output of the baud <u>rate</u> generator may be echoed out via the <u>TRxC</u> pin.

The following formula relates the time constant to the baud rate (the baud rate is in bits/second and the BR clock period is in seconds):

| baud rate |   | 1                                                |
|-----------|---|--------------------------------------------------|
| Daug rate | = | 2 (time constant + 2) $\times$ (BR clock period) |

**Digital Phase-Locked Loop.** The SCC contains a Digital Phase-Locked-Loop (DPLL) to recover clock information from a data stream with NRZI or FM encoding. The DPLL is driven by a clock that is nominally 32 (NRZI) or 16 (FM) times the data rate. The DPLL uses this clock, along with the data stream, to construct a clock for the data. This clock may then be used as the SCC recive clock, the transmit clock, or both.

For NRZI encoding, the DPLL counts the 32x clock to create nominal bit times. As the 32x clock is counted, the DPLL is searching the incoming data stream for edges (either 1 to 0 or 0 to 1). Whenever an edge is detected, the DPLL makes a count adjustment (during the next counting cycle), producing a terminal count closer to the center of the bit cell.

For FM encoding, the DPLL still counts from 0 to 31, but with a cycle corresponding to two bit times. When the DPLL is locked, the clock edges in the data stream should occur between counts 15 and 16 and between counts 31 and 0. The DPLL looks for edges only during a time centered on the 15 to 16 counting transition.

The 32x clock for the DPLL can be programmed to come from either the  $\overline{RTxC}$  input or the output of the baud rate generator. The DPLL output may be programmed to be echoed out of the SCC via the  $\overline{TRxC}$  pin (if this pin is not being used as an input).

Data Encoding. The SCC may be programmed to encode and decode the serial data in four different ways (Figure 6). In NRZ encoding, a 1 is represented by a High level and a 0 is represented by a Low level. In NRZI encoding, a l is represented by no change in level and a 0 is represented by a change in level. In FM1 (more properly, bi-phase mark). a transition occurs at the beginning of every bit cell. A 1 is represented by an additional transition at the center of the bit cell and a 0 is represented by no additional transition at the center of the bit cell. In FMO (bi-phase space), a transition occurs at the beginning of every bit cell. A 0 is represented by an additional transition at the center of the bit cell, and a 1 is represented by no additional transition at the center of the bit cell. In addition to these four methods, the SCC can be used to decode



Figure 6. Data Encoding Methods



Manchester (bi-phase level) data by using the DPLL in the FM mode and programming the receiver for NRZ data. Manchester encoding always produces a transition at the center of the bit cell. If the transition is 0 to 1, the bit is a 0. If the transition is 1 to 0, the bit is a 1.

Auto Echo and Local Loopback. The SCC is capable of automatically echoing everything it receives. This feature is useful mainly in Asynchronous modes, but works in Synchronous and SDLC modes as well. In Auto Echo mode, TxD is RxD. Auto Echo mode can be used with NRZI or FM encoding with no additional delay, because the data stream is not decoded before retransmission. In Auto Echo mode, the  $\overline{\text{CTS}}$  input is ignored as a transmitter enable (although transitions on this input can still cause interrupts if programmed to do so). In this mode, the transmitter is actually bypassed and the programmer is responsible for disabling transmitter interrupts and WAIT/REQUEST on transmit.

The SCC is also capable of local loopback. In this mode TxD is RxD, just as in Auto Echo mode. However, in Local Loopback mode, the internal transmit data is tied to the internal receive data and RxD is ignored (except to be echoed out via TxD). The CTS and DCD inputs are also ignored as transmit and receive enables. However, transitions on these inputs can still cause interrupts. Local Loopback works in Asynchronous, Synchronous and SDLC modes with NRZ, NRZI or FM coding of the data stream.

**I/O Interface Capabilities.** The SCC offers the choice of Polling, Interrupt (vectored or nonvectored), and Block Transfer modes to transfer data, status, and control information to and from the CPU. The Block Transfer mode can be implemented under CPU or DMA control.

**Polling.** All interrupts are disabled. Three status registers in the SCC are automatically updated whenever any function is performed. For example, end-of-frame in SDLC mode sets a bit in one of these status registers. The idea behind polling is for the CPU to periodically read a status register until the

register contents indicate the need for data to be transferred. Only one register needs to be read; depending on its contents, the CPU either writes data, reads data, or continues. Two bits in the register indicate the need for data transfer. An alternative is a poll of the Interrupt Pending register to determine the source of an interrupt. The status for both channels resides in one register.

**Interrupts.** When an SCC responds to an Interrupt Acknowledge signal (INTACK) from the CPU, an interrupt vector may be placed on the data bus. This vector is written in WR2 and may be read in RR2A or RR2B (Figures 10 and 11).

To speed interrupt response time, the SCC can modify three bits in this vector to indicate status. If the vector is read in Channel A, status is never included; if it is read in Channel B, status is always included.

Each of the six sources of interrupts in the SCC (Transmit, Receive, and External/Status interrupts in both channels) has three bits associated with the interrupt source: Interrupt Pending (IP), Interrupt Under Service (IUS), and Interrupt Enable (IE). Operation of the IE bit is straightforward. If the IE bit is set for a given interrupt source, then that source can request interrupts. The exception is when the MIE (Master Interrupt Enable) bit in WR9 is reset and no interrupts may be requested. The IE bits are write only.

The other two bits are related to the interrupt priority chain (Figure 7). As a microprocessor peripheral, the SCC may request an interrupt only when no higher priority device is requesting one, e.g., when IEI is High. If the device in question requests an interrupt, it pulls down INT. The CPU then responds with INTACK, and the interrupting device places the vector on the data bus.

In the SCC, the IP bit signals a need for interrupt servicing. When an IP bit is 1 and the IEI input is High, the INT output is pulled Low, requesting an interrupt. In the SCC, if the IE bit is not set by enabling interrupts, then the IP for that source can never be set. The IP bits are readable in RR3A.





Figure 7. Interrupt Schedule

The IUS bits signal that an interrupt request is being serviced. If an IUS is set, all interrupt sources of lower priority in the SCC and external to the SCC are prevented from requesting interrupts. The internal interrupt sources are inhibited by the state of the internal daisy chain, while lower priority devices are inhibited by the IEO output of the SCC being pulled Low and propagated to subsequent peripherals. An IUS bit is set during an Interrupt Acknowledge cycle if there are no higher priority devices requesting interrupts.

There are three types of interrupts: Transmit, Receive, and External/Status. Each interrupt type is enabled under program control with Channel A having higher priority than Channel B, and with Receiver, Transmit, and External/Status interrupts prioritized in that order within each channel. When the Transmit interrupt is enabled, the CPU is interrupted when the transmit buffer becomes empty. (This implies that the transmitter must have had a data character written into it so that it can become empty.) When enabled, the receiver can interrupt the CPU in one of three ways:

- Interrupt on First Receive Character or Special Receive Condition.
- Interrupt on All Receive Characters or Special Receive Condition.
- Interrupt on Special Receive Condition Only.

Interrupt on First Character or Special Condition and Interrupt on Special Condition Only are typically used with the Block Transfer mode. A Special Receive Condition is one of the following: receiver overrun, framing error in Asynchronous mode, end-of-frame in SDLC mode and, optionally, a parity error. The Special Receive Condition interrupt is different from an ordinary receive character available interrupt only in the status placed in the vector during the Interrupt Acknowledge cycle. In Interrupt on First Receive Character, an interrupt can occur from Special Receive Conditions any time after the first receive character interrupt.

The main function of the External/Status interrupt is to monitor the signal transitions of the CTS, DCD, and SYNC pins; however, an External/Status interrupt is also caused by a Transmit Underrun condition, or a zero count in the baud rate generator, or by the detection of a Break (Asynchronous mode), Abort (SDLC mode) or EOP (SDLC Loop mode) sequence in the data stream. The interrupt caused by the Abort or EOP has a special feature allowing the SCC to interrupt when the Abort or EOP sequence is detected or terminated. This feature facilitates the proper termination of the current message, correct initialization of the next message, and the accurate timing of the Abort condition in external logic in SDLC mode. In SDLC Loop mode, this feature allows secondary stations to recognize the wishes of the primary station to regain control of the loop during a poll sequence.

**CPU/DMA Block Transfer.** The SCC provides a Block Transfer mode to accommodate CPU block transfer functions and DMA controllers.



The Block Transfer mode uses the WAIT/ REQUEST output in conjunction with the Wait/Request bits in WR1. The WAIT/ REQUEST output can be defined under software control as a WAIT line in the CPU Block Transfer mode or as a REQUEST line in the DMA Block Transfer mode. To a DMA controller, the SCC REQUEST output indicates that the SCC is ready to transfer data to or from memory. To the CPU, the WAIT line indicates that the SCC is not ready to transfer data, thereby requesting that the CPU extend the I/O cycle. The DTR/ REQUEST line allows full-duplex operation under DMA control.

#### Architecture

The SCC internal structure includes two fullduplex channels, two baud rate generators, internal control and interrupt logic, and a bus interface to a nonmultiplexed bus. Associated with each channel are a number of read and write registers for mode control and status information, as well as logic necessary to interface to modems or other external devices (Figure 8).

The logic for both channels provides formats, synchronization, and validation for data transferred to and from the channel interface. The modem control inputs are monitored by the control logic under program control. All of the modem control signals are generalpurpose in nature and can optionally be used for functions other than modem control.

The register set for each channel includes ten control (write) registers, two synccharacter (write) registers, and four status (read) registers. In addition, each baud rate generator has two (read/write) registers for holding the time constant that determines the baud rate. Finally, associated with the interrupt logic is a write register for the interrupt vector accessible through either channel, a



Figure 8. Block Diagram of SCC Architecture









#### Architecture (Continued)

write only Master Interrupt Control register and three read registers: one containing the vector with status infomation (Channel B only), one containing the vector without status (Channel A only), and one containing the Interrupt Pending bits (Channel A only).

The registers for each channel are designated as follows:

WR0-WR15 — Write Registers 0 through 15.

RR0-RR3, RR10, RR12, RR13, RR15 — Read Registers 0 through 3, 10, 12, 13, 15.

Table 1 lists the functions assigned to each read or write register. The SCC contains only one WR2 and WR9, but they can be accessed by either channel. All other registers are paired (one for each channel).

**Data Path.** The transmit and receive data path illustrated in Figure 9 is identical for both channels. The receiver has three 8-bit buffer registers in an FIFO arrangement, in addition to the 8-bit receive shift register. This scheme creates additional time for the CPU to service an interrupt at the beginning of a block of high speed data. Incoming data is routed through one of several paths (data or CRC) depending on the selected mode (the character length in Asynchronous modes also determines the data path).

The transmitter has an 8-bit Transmit Data buffer register loaded from the internal data bus and a 20-bit Transmit Shift register that can be loaded either from the synchronous character registers or from the Transmit Data register. Depending on the operational mode, outgoing data is routed through one of four main paths before it is transmitted from the Transmit Data output (TxD)

#### Programming

The SCC contains 13 write registers in each channel that are programmed by the system separately to configure the functional personality of the channels.

In the SCC, register addressing is direct for the data registers only, which are selected by a High on the  $D/\overline{C}$  pin. In all other cases (with

#### **Read Register Functions**

| RRO  | Transmit/Receive buffer status and External status                                         |
|------|--------------------------------------------------------------------------------------------|
| RR1  | Special Receive Condition status                                                           |
| RR2  | Modified interrupt vector (Channel B only)<br>Unmodified interrupt vector (Channel A only) |
| RR3  | Interrupt Pending bits (Channel A only)                                                    |
| RR8  | Receive buffer                                                                             |
| RR10 | Miscellaneous status                                                                       |
| RR12 | Lower byte of baud rate generator time constant                                            |
| RR13 | Upper byte of baud rate generator time constant                                            |
| RR15 | External/Status interrupt information                                                      |

#### Write Register Functions

| WR0  | CRC initialize, initialization commands for the various modes, Register Pointers |
|------|----------------------------------------------------------------------------------|
| WRl  | Transmit/Receive interrupt and data transfer mode definition                     |
| WR2  | Interrupt vector (accessed through either channel)                               |
| WR3  | Receive parameters and control                                                   |
| WR4  | Transmit/Receive miscellaneous parameters and modes                              |
| WR5  | Transmit parameters and controls                                                 |
| WR6  | Sync characters or SDLC address field                                            |
| WR7  | Sync character or SDLC flag                                                      |
| WR8  | Transmit buffer                                                                  |
| WR9  | Master interrupt control and reset (accessed through either channel)             |
| WR10 | Miscellaneous transmitter/receiver control bits                                  |
| WR11 | Clock mode control                                                               |
| WR12 | Lower byte of baud rate generator time constant                                  |
| WR13 | Upper byte of baud rate generator time constant                                  |
| WR14 | Miscellaneous control bits                                                       |
| WR15 | External/Status interrupt control                                                |

Table 1. Read and Write Register Functions

the exception of WR0 and RR0), programming the write registers requires two write operations and reading the read registers requires both a write and a read operation. The first write is to WR0 and contains three bits that point to the selected register. The second write is the actual control word for the selected

28530 SCC

#### Programming (Continued)

register, and if the second operation is read, the selected read register is accessed. All of the registers in the SCC, including the data registers, may be accessed in this fashion. The pointer bits are automatically cleared after the read or write operation so that WR0 (or RR0) is addressed again.

The system program first issues a series of commands to initialize the basic mode of operation. This is followed by other commands to qualify conditions within the selected mode. For example, the Asynchronous mode, character length, clock rate, number of stop bits, even or odd parity might be set first. Then the interrupt mode would be set, and finally, receiver or transmitter enable.

#### Read Register 0

 Dr
 Ds
 Ds
 Ds
 Ds
 Ds
 Ds

 Image: Constraint of the state of the state

#### Read Register 1



#### **Read Register 2**



**Read Registers.** The SCC contains eight read registers (actually nine, counting the receive buffer (RR8) in each channel). Four of these may be read to obtain status information (RR0, RR1, RR10, and RR15). Two registers (RR12 and RR13) may be read to learn the baud rate generator time constant. RR2 contains either the unmodified interrupt vector (Channel A) or the vector modified by status information (Channel B). RR3 contains the Interrupt Pending (IP) bits (Channel A). Figure 10 shows the formats for each read register.

The status bits of RR0 and RR1 are carefully grouped to simplify status monitoring; e.g., when the interrupt vector indicates a Special Receive Condition interrupt, all the appropriate error bits can be read from a single register (RR1).

Read Register 3





#### Programming (Continued)



#### Read Register 15



Figure 10. Read Register Bit Functions (Continued)

Write Register 1

Write Registers. The SCC contains 13 write registers (14 counting WR8, the transmit buffer) in each channel. These write registers are programmed separately to configure the functional "personality" of the channels. In addition, there are two registers (WR2 and

#### WR9) shared by the two channels that may be accessed through either of them. WR2 contains the interrupt vector for both channels, while WR9 contains the interrupt control bits. Figure 11 shows the format of each write register.



Figure 11. Write Register Bit Functions

#### Write Register 0



#### Programming (Continued)

#### Write Register 3



#### Write Register 4



#### Write Register 5



#### Write Register 6



#### Write Register 7



#### Figure 11. Write Register Bit Functions (Continued)



#### Programming (Continued)





#### Write Register 10



#### Write Register 11



#### Write Register 12



#### Write Register 13



## UPPER BYTE OF

#### Write Register 14



#### Write Register 15







#### Timing

The SCC generates internal control signals from  $\overline{WR}$  and  $\overline{RD}$  that are related to PCLK. Since PCLK has no phase relationship with  $\overline{WR}$  and  $\overline{RD}$ , the circuitry generating these internal control signals must provide time for metastable conditions to disappear. This gives rise to a recovery time related to PCLK. The recovery time applies only between bus transactions involving the SCC. The recovery time required for proper operation is specified from the rising edge of  $\overline{WR}$  or  $\overline{RD}$  in the first transaction involving the SCC to the falling edge of WR or RD in the second transaction involving the SCC. This time must be at least 6 PCLK cycles plus 200 ns.

**Read Cycle Timing.** Figure 12 illustrates Read cycle timing. Addresses on A/B and D/ $\overline{C}$ and the status on INTACK must remain stable throughout the cycle. If  $\overline{CE}$  falls after  $\overline{RD}$  falls or if it rises before  $\overline{RD}$  rises, the effective  $\overline{RD}$  is shortened.



Figure 12. Read Cycle Timing



#### Timing (Continued)

Write Cycle Timing. Figure 13 illustrates Write cycle timing. Addresses on  $A/\overline{B}$  and  $D/\overline{C}$  and the status on INTACK must remain stable

throughout the cycle. If  $\overline{CE}$  falls after  $\overline{WR}$  falls or if it rises before  $\overline{WR}$  rises, the effective  $\overline{WR}$  is shortened.



Figure 13. Write Cycle Timing

**Interrupt Acknowledge Cycle Timing.** Figure 14 illustrates Interrupt Acknowledge cycle timing. Between the time INTACK goes Low and the falling edge of RD, the internal and external IEI/IEO daisy chains settle. If there is an interrupt pending in the SCC and IEI is

High when  $\overline{RD}$  falls, the Acknowledge cycle is intended for the SCC. In this case, the SCC may be programmed to respond to  $\overline{RD}$  Low by placing its interrupt vector on D<sub>0</sub>-D<sub>7</sub> and it then sets the appropriate Interrupt-Under-Service latch internally.



Figure 14. Interrupt Acknowledge Cycle Timing



#### **Absolute Maximum Ratings**

| Voltages on all inputs and outputs   |
|--------------------------------------|
| with respect to GND0.3 V to $+7.0$ V |
| Operating Ambient                    |
| Temperature As Specified in          |
| Ordering Information                 |
| Storage Temperature65°C to +150°C    |

**Standard Test Conditions** 

**DC Characteristics** 

The characteristics below apply for the following standard test conditions, unless otherwise noted. All voltages are referenced to GND. Positive current flows into the referenced pin. Standard conditions are as follows: Stresses greater than those listed under Absolute Maximum Ratings may cause permanent damage to the device. This is a stress rating only; operation of the device at any condition above those indicated in the operational sections of these specifications is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

- $\blacksquare$  +4.75 V  $\leq$  V\_{\rm CC}  $\leq$  +5.25 V
- $\blacksquare$  GND = 0 V
- T<sub>A</sub> as specified in Ordering Information

All ac parameters assume a load capacitance of 50 pF max.



Figure 16. Open-Drain Test Load

|                           | + 5 V      |
|---------------------------|------------|
| FROM OUTPUT<br>UNDER TEST | -+K-}<br>₹ |
| 100 pF 🕇                  |            |
| Ţ                         | ŢŢ         |

Figure 15. Standard Test Load

| Symbol          | Parameter                      | Min  | Max                  | Unit | Condition                    |
|-----------------|--------------------------------|------|----------------------|------|------------------------------|
| V <sub>IH</sub> | Input High Voltage             | 2.0  | V <sub>CC</sub> +0.3 | V    |                              |
| V <sub>IL</sub> | Input Low Voltage              | -0.3 | 0.8                  | V    |                              |
| V <sub>OH</sub> | Output High Voltage            | 2.4  |                      | V    | $I_{OH} = -250 \ \mu A$      |
| V <sub>OL</sub> | Output Low Voltage             |      | 0.4                  | V    | $I_{OL} = +2.0 \text{ mA}$   |
| IIL             | Input Leakage                  |      | ±10.0                | μA   | $0.4 \leq V_{IN} \leq +2.4V$ |
| I <sub>OL</sub> | Output Leakage                 |      | ±10.0                | μA   | $0.4 \le V_{OUT} \le +2.4V$  |
| I <sub>CC</sub> | V <sub>CC</sub> Supply Current |      | 250                  | mA   |                              |

 $V_{CC}$  = 5 V ± 5% unless otherwise specified, over specified temperature range.



#### Capacitance

| Symbol                                                                        | Parameter                         | Min  | Μαχ | Unit | Test Condition       |
|-------------------------------------------------------------------------------|-----------------------------------|------|-----|------|----------------------|
| C <sub>IN</sub>                                                               | C <sub>IN</sub> Input Capacitance |      | 10  | pF   | Unmeasured Pins      |
| C <sub>OUT</sub> Output Capacitance<br>C <sub>I/O</sub> Bidirectional Capacit |                                   |      | 15  | pF   | Returned to Ground   |
|                                                                               |                                   | ance | 20  | pF   | notarinoa to circana |

f = 1 MHz, over specified temperature range.

#### **Read and Write Timing**





| Number | Symbol           | Parameters                                      | Min(ns) | Max(ns) | Notes* |
|--------|------------------|-------------------------------------------------|---------|---------|--------|
| 1      | TwPC1            | PCLK Low Width                                  | 105     | 2000    |        |
| 2      | TwPCh            | PCLK High Width                                 | 105     | 2000    |        |
| 3      | TfPC             | PCLK Fall Time                                  |         | 20      |        |
| 4      | TrPC             | PCLK Rise Time                                  |         | 20      |        |
| 5      | TcPC             | PCLK Cycle Time                                 | 250     | 4000    |        |
| 6      | TsA(WR)          | Address to WR   Setup Time                      | 80      |         |        |
| 7      | Th <b>A</b> (WR) | Address to WR † Hold Time                       | 0       |         |        |
| 8      | TsA(RD)          | Address to RD ↓ Setup Time                      | 80      |         |        |
| 9      | ThA(RD)          | Address to $\overline{\mathrm{RD}}$ † Hold Time | 0       |         |        |
| 10     | TsIA(PC)         | INTACK to PCLK 1 Setup Time                     | 0       |         |        |
| 11     | TsIAi(WR)        | INTACK to WR   Setup Time                       | 200     |         | 1      |
| 12     | ThIA(WR)         | INTACK to WR   Hold Time                        | 0       |         |        |
| 13     | TsIAi(RD)        | INTACK to RD   Setup Time                       | 200     |         | 1      |
| 14     | ThIA(RD)         | INTACK to RD † Hold Time                        | 0       |         |        |
| 15     | ThIA(PC)         | INTACK to PCLK   Hold Time                      | 100     |         |        |
| 16     | TsCE1(WR)        | CE Low to WR ↓ Setup Time                       | 0       |         |        |
| 17     | ThCE(WR)         | CE to WR † Hold Time                            | 0       |         |        |
| 18     | TsCEh(WR)        | CE High to WR↓ Setup Time                       | 100     |         |        |
| 19     | TsCE1(RD)        | CE Low to RD ↓ Setup Time                       | 0       |         | 1      |
| 20     | ThCE(RD)         | CE to RD † Hold Time                            | 0       |         | 1      |
| 21     | TsCEh(RD)        | CE High to RD   Setup Time                      | 100     |         | 1      |
| 22     | TwRD1            | RD Low Width                                    | 390     |         | 1      |
| 23     | TdRD(DRA)        | RD ↓ to Read Data Active Delay                  | 0       |         |        |
| 24     | TdRDr(DR)        | RD † to Read Data Not Valid Delay               | 0       |         |        |
| 25     | TdRDf(DR)        | RD ↓ to Read Data Valid Delay                   |         | 255     |        |
| 26     | TdRD(DRz)        | RD † to Read Data Float Delay                   |         | 70      | 2      |

#### Read and Write Timing (Continued)

NOTES:

1. Parameter does not apply to Interrupt Acknowledge transactions.

2. Float delay is defined as the time required for a  $\pm 0.5$  V change in the output with a maximum dc load and minimum ac load.



#### Interrupt Acknowledge Timing



#### **Reset Timing**





| Number | Symbol          | Parameters                                             | Min(ns) | Max(ns) | Notes* |
|--------|-----------------|--------------------------------------------------------|---------|---------|--------|
| 27     | TdA(DR)         | Address Required Valid to Read Data Valid Delay        |         | 590     |        |
| 28     | TwWR1           | WR Low Width                                           | 390     |         |        |
| 29     | TsDW(WR)        | Write Data to WR I Setup Time                          | 0       |         |        |
| 30     | ThDW(WR)        | Write Data to WR 1 Hold Time                           | 0       |         |        |
| 31     | - TdWR(W)       | WR↓ to Wait Valid Delay                                |         |         |        |
| 32     | TdRD(W)         | RD↓ to Wait Valid Delay                                |         | 240     | 4      |
| 33     | TdWRf(REQ)      | WR I to W/REQ Not Valid Delay                          |         | 240     |        |
| 34     | TdRDf(REQ)      | RD 1 to W/REQ Not Valid Delay                          |         | 240     |        |
| 35     | TdWRr(REQ)      | WR 1 to DTR/REQ Not Valid Delay                        |         | 5TcPC   |        |
|        |                 |                                                        |         | + 300   |        |
| 36     | - TdRDr(REQ)    |                                                        |         | -5TcPC  |        |
|        |                 |                                                        |         | + 300   |        |
| 37     | TdPC(INT)       | PCLK 4 to INT Valid Delay                              |         | 500     | 4      |
| 38     | TdIAi(RD)       | INTACK to RD ↓ (Acknowledge) Delay                     |         |         | 5      |
| 39     | TwRDA           | RD (Acknowledge) Width                                 | 285     |         |        |
| 40     | – TdRDA(DR) ––– | — RD ↓ (Acknowledge) to Read Data Valid Delay ——       |         | 190     |        |
| 41     | TsIEI(RDA)      | IEI to RD ↓ (Acknowledge) Setup Time                   | 120     |         |        |
| 42     | ThIEI(RDA)      | IEI to $\overline{	ext{RD}}$ † (Acknowledge) Hold Time | 0       |         |        |
| 43     | TdIEI(IEO)      | IEI to IEO Delay Time                                  |         | 120     |        |
| 44     | TdPC(IEO)       | PCLK † to IEO Delay                                    |         | 250     |        |
| 45     | – TdRDA(INT) —  | - RD I to INT Inactive Delay                           |         | 500     |        |
| 46     | TdRD(WRQ)       | RD 1 to WR I Delay for No Reset                        | 30      |         |        |
| 47     | TdWRQ(RD)       | WR ↑ to RD ↓ Delay for No Reset                        | 30      |         |        |
| 48     | TwRES           | WR and RD Coincident Low for Reset                     | 250     |         |        |
| 49     | Trc             | Valid Access Recovery Time                             | 6TcPC   |         |        |
|        |                 |                                                        | + 200   |         | 3      |

NOTES:

3. Parameter applies only between transactions involving the SCC.

Open-drain output, measured with open-drain test load.
 Parameter is system dependent. For any SCC in the daisy chain, TdIAi(RD) must be greater than the sum of TdPC(IEO)

for the highest priority device in the daisy chain, TsIEI(RDA) for the SCC, and TdIEIf(IEO) for each device separating them in the daisy chain.

\*Timings are preliminary and subject to change.



#### General Timing

| Number | Symbol         | Parameters                                                                 | Min(ns)        | Max(ns) | Notes* |
|--------|----------------|----------------------------------------------------------------------------|----------------|---------|--------|
| 1      | TdPC(REQ)      | PCLK I to W/REQ Valid Delay                                                |                | 250     |        |
| 2      | TdPC(W)        | PCLK↓ to Wait Inactive Delay                                               |                | 350     |        |
| 3      | TsRXC(PC)      | RxC † to PCLK † Setup Time                                                 | 50             |         | 1,4    |
| 4      | TsRXD(RXCr)    | $RxD$ to $\overline{RxC}$ † Setup Time (X1 Mode)                           | 0              |         | 1      |
| 5      | — ThRXD(RXCr)- | -RxD to RxC † Hold Time (X1 Mode)                                          |                |         | l      |
| 6      | TsRXD(RXCf)    | RxD to $\overline{RxC}$ + Setup Time (X1 Mode)                             | 0              |         | 1,5    |
| 7      | ThRXD(RXCf)    | RxD to $\overline{RxC} \downarrow$ Hold Time (X1 Mode)                     | 150            |         | 1,5    |
| 8      | TsSY(RXC)      | SYNC to RxC 1 Setup Time                                                   | -200           |         | 1      |
| 9      | ThSY(RXC)      | $\overline{\text{SYNC}}$ to $\overline{\text{RXC}}$ <sup>†</sup> Hold Time | 3TcPC<br>+ 200 |         | 1      |
| 10     | — TsTXC(PC) —— |                                                                            | 0              |         |        |
| 11     | TdTXCf(TXD)    | TxC↓ to TxD Delay (X1 Mode)                                                |                | 300     | 2      |
| 12     | TdTXCr(TXD)    | $\overline{\text{TxC}}$ † to TxD Delay (X1 Mode)                           |                | 300     | 2,5    |
| 13     | TdTXD(TRX)     | TxD to TRxC Delay (Send Clock Echo)                                        |                |         |        |
| 14     | TwRTXh         | RTxC High Width                                                            | 180            |         |        |
| 15     | TwRTX1         | - RTxC Low Width                                                           | 180            |         |        |
| 16     | TcRTX          | RTxC Cycle Time                                                            | 400            |         |        |
| 17     | TcRTXX         | Crystal Oscillator Period                                                  | 250            | 1000    | 3      |
| 18     | TwTRXh         | TRxC High Width                                                            | 180            |         |        |
| 19     | TwTRX1         | TRxC Low Width                                                             | 180            |         |        |
| 20     | — TcTRX ———    | - TRxC Cycle Time                                                          | 400            |         |        |
| 21     | TwEXT          | DCD or CTS Pulse Width                                                     | 200            |         |        |
| 22     | TwSY           | SYNC Pulse Width                                                           | 200            |         |        |

NOTES: 1.  $\overline{RxC}$  is  $\overline{RTxC}$  or  $\overline{TRxC}$ , whichever is supplying the receive

 $\begin{array}{l} \text{Intro is Intro or TRXC, which even is supplying the transmit}\\ \text{Clock.}\\ \text{3. TrXC is TRXC or RTXC, which even is supplying the transmit}\\ \text{Clock.}\\ \text{3. Both RTXC and SYNC have 30 pF capacitors to ground con-$ 

nected to them.

Parameter applies only if the data rate is one-fourth the PCLK rate. In all other cases, no phase relationship between RxC and PCLK or TxC and PCLK is required.

5. Parameter applies only to FM encoding/decoding.

\*Timings are preliminary and subject to change.



#### General Timing (Continued)





#### System Timing



| Number | Symbol         | Parameter                                                                                            | Min | Μαχ | Units  | Notes* |
|--------|----------------|------------------------------------------------------------------------------------------------------|-----|-----|--------|--------|
| 1      | TdRXC (REQ)    | RxC † to W/REQ Valid Delay                                                                           | 8   | 12  | TcPC   | 2      |
| 2      | TdRXC(W)       | RxC † to Wait Inactive Delay                                                                         | 8   | 12  | TcPC   | 1,2    |
| 3      | TdRXC(SY)      | RxC † to SYNC Valid Delay                                                                            | 4   | 7   | TcPC   | 2      |
| 4      | TdRXC(INT)     | RxC 1 to INT Valid Delay                                                                             | 10  | 16  | TcPC   | 1,2    |
| 5      | — TdTXC(REQ) — | - TxC I to W/REQ Valid Delay-                                                                        | 5   | 8   | TcPC - | 3      |
| 6      | TdTXC(W)       | TxC ↓ to Wait Inactive Delay                                                                         | 5   | 8   | TcPC   | 1,3    |
| 7      | TdTXC(DRQ)     | TxC I to DTR/REQ Valid Delay                                                                         | 4   | 7   | TcPC   | 3      |
| 8      | TdTXC(INT)     | TxC I to INT Valid Delay                                                                             | 6   | 10  | TcPC   | 1,3    |
| 9      | TdSY(INT)      | SYNC Transition to INT Valid Delay                                                                   | 2   | 6   | TcPC   | 1      |
| 10     | TdEXT(INT)     | $\overline{\text{DCD}}$ or $\overline{\text{CTS}}$ Transition to $\overline{\text{INT}}$ Valid Delay | 2   | 6   | TcPC   | 1      |

#### System Timing (Continued)

NOTES:

3.  $\overline{TxC}$  is  $\overline{TRxC}$  or  $\overline{RTxC}$ , whichever is supplying the transmit clock. \*Timings are preliminary and subject to change.

Z8530 SCC

Open-drain output, measured with open-drain test load.
 RxC is RTxC or TRxC, whichever is supplying the receive clock.

#### Ordering Information

| Туре                        | Package                                                              | Temp                                         | Clock | Description                               |
|-----------------------------|----------------------------------------------------------------------|----------------------------------------------|-------|-------------------------------------------|
| Z8530 B1<br>B6<br>D1        | Plastic 40 pin<br>Plastic 40 pin<br>Ceramic 40 pin                   | 0/+70°C<br>-40/+85°C<br>0/+70°C              | 4MHz  | Z8530 Serial Communications<br>Controller |
| D2<br>D6                    | Ceramic 40 pin<br>Ceramic 40 pin                                     | -5S/+125°C<br>-40/+85°C                      |       |                                           |
| Z8530A B1<br>B6<br>D1<br>D6 | Plastic 40 pin<br>Plastic 40 pin<br>Ceramic 40 pin<br>Ceramic 40 pin | 0/+70°C<br>-40/+85°C<br>0/+70°C<br>-40/+85°C | 6MHz  |                                           |

#### Packages

Plastic

Ceramic





### Counter/Timer and Parallel I/O Unit



#### Features

- Two independent 8-bit, double-buffered, bidirectional I/O ports plus a 4-bit special-purpose I/O port. I/O ports feature programmable polarity, programmable direction (Bit mode), "pulse catchers," and programmable opendrain outputs.
- Four handshake modes, including 3-Wire (like the IEEE-488).
- REQUEST/WAIT signal for high-speed data transfer.

#### **General Description**

The Z8536 CIO Counter/Timer and Parallel I/O element is a general-purpose peripheral circuit, satisfying most counter/ timer and parallel I/O needs encountered in system designs. This versatile device contains three I/O ports and three counter/timers. Many programmable options tailor its configuration to specific applications. The use of the device is simplified by making all internal registers

- Flexible pattern-recognition logic, programmable as a 16-vector interrupt controller.
- Three independent 16-bit counter/timers with up to four external access lines per counter/timer (count input, output, gate, and trigger), and three output duty cycles (pulsed, one-shot, and square-wave), programmable as retriggerable or nonretriggerable.
- Easy to use since all registers are read/write.

(command, status, and data) readable and (except for status bits) writable. In addition, each register is given its own unique internal address, so that any register can be accessed in two operations. All data registers can be directly accessed in a single operation. The CIO is easily interfaced to all popular microprocessors.



Figure 1. Logic Functions



Figure 2. Pin Configurations



### **Pin Description**

**A<sub>0</sub>-A<sub>1</sub>.** Address Lines (input). These two lines are used to select the register involved in the CPU transaction: Port A's Data register, Port B's Data register, Port C's Data register, or a control register.

**CE.** Chip Enable (input, active Low). A Low level on this input enables the CIO to be read from or written to.

**D**<sub>0</sub>-**D**<sub>7</sub>. Data Bus (bidirectional 3-state). These eight data lines are used for transfers between the CPU and the CIO.

**IEI.** Interrupt Enable In (input, active High). IEI is used with IEO to form an interrupt daisy chain when there is more than one interruptdriven device. A High IEI indicates that no other higher priority device has an interrupt under service or is requesting an interrupt.

**IEO.** Interrupt Enable Out (output, active High). IEO is High only if IEI is High and the CPU is not servicing an interrupt from the requesting CIO or is not requesting an interrupt (Interrupt Acknowledge cycle only). IEO is connected to the next lower priority device's IEI input and thus inhibits interrupts from lower priority devices.

**INT.** Interrupt Request (output, open-drain, active Low). This signal is pulled Low when the CIO requests an interrupt.

**INTACK.** Interrupt Acknowledge (input, active Low). This input indicates to the CIO that an <u>Interrupt</u> Acknowledge cycle is in progress. <u>INTACK</u> must be synchronized to PCLK, and it must be stable throughout the Interrupt Acknowledge cycle.

**PA<sub>0</sub>-PA<sub>7</sub>.** Port A I/O lines (bidirectional, 3-state, or open-drain). These eight I/O lines transfer information between the CIO's Port A and external devices.

**PB<sub>0</sub>-PB<sub>7</sub>.** Port B I/O lines (bidirectional, 3-state, or open-drain). These eight I/O lines transfer information between the CIO's Port B and external devices. May also be used to provide external access to Counter/Timers 1 and 2.

**PC<sub>0</sub>-PC<sub>3</sub>.** Port C I/O lines (bidirectional, 3-state, or open-drain). These four I/O lines are used to provide handshake, WAIT, and REQUEST lines for Ports A and B or to provide external access to Counter/Timer 3 or access to the CIO's Port C.

**PCLK.** Peripheral Clock (input, TTLcompatible). This is the clock used by the internal control logic and the counter/timers in timer mode. It does not have to be the CPU clock.

**RD\*.** Read (input, active Low). This signal indicates that a CPU is reading from the CIO. During an Interrupt Acknowledge cycle, this signal gates the interrupt vector onto the data bus if the CIO is the highest priority device requesting an interrupt.

**WR\*.** Write (input, active Low). This signal indicates a CPU write to the CIO.

\*When  $\overline{RD}$  and  $\overline{WR}$  are detected Low at the same time (normally an illegal condition), the CIO is reset.

### Architecture

The CIO Counter/Timer and Parallel I/O element (Figure 3) consists of a CPU interface, three I/O ports (two general-purpose 8-bit ports and one special-purpose 4-bit port), three 16-bit counter/timers, an interruptcontrol logic block, and the internal-control logic block. An extensive number of programmable options allow the user to tailor the configuration to best suit the specific application.

The two general-purpose 8-bit I/O ports

(Figure 4) are identical, except that Port B can be specified to provide external access to Counter/Timers 1 and 2. Either port can be programmed to be a handshake-driven, double-buffered port (input, output, or bidirectional) or a control-type port with the direction of each bit individually programmable. Each port includes pattern-recognition logic, allowing interrupt generation when a specific pattern is detected. The pattern-recognition logic



### Architecture (Continued)



Figure 3. CIO Block Diagram







### Architecture (Continued)

can be programmed so the port functions like a priority-interrupt controller. Ports A and B can also be linked to form a 16-bit I/O port.

To control these capabilities, both ports contain 12 registers. Three of these registers, the Input, Output, and Buffer registers, comprise the data path registers. Two registers, the Mode Specification and Handshake Specification registers, are used to define the mode of the port and to specify which handshake, if any, is to be used. The reference pattern for the pattern-recognition logic is defined via three registers: the Pattern Polarity, Pattern Transition, and Pattern Mask registers. The detailed characteristics of each bit path (for example, the direction of data flow or whether a path is inverting or noninverting) are programmed using the Data Path Polarity, Data Direction, and Special I/O Control registers.

The primary control and status bits are

grouped in a single register, the Command and Status register, so that after the port is initially configured, only this register must be accessed frequently. To facilitate initialization, the port logic is designed so that registers associated with an unrequired capability are ignored and do not have to be programmed.

The function of the special-purpose 4-bit port, Port C (Figure 5), depends upon the roles of Ports A and B. Port C provides the required handshake lines. Any bits of Port C not used as handshake lines can be used as I/O lines or to provide external access for the third counter/timer.

Since Port C's function is defined primarily by Ports A and B, only three registers (besides the Data Input and Output registers) are needed. These registers specify the details of each bit path: the Data Path Polarity, Data Direction, and Special I/O Control registers.



Figure 5. Port C Block Diagram

Architecture (Continued)

The three counter/timers (Figure 6) are all identical. Each is comprised of a 16-bit downcounter, a 16-bit Time Constant register (which holds the value loaded into the downcounter), a 16-bit Current Count register (used to read the contents of the down-counter), and two 8-bit registers for control and status (the Mode Specification and the Command and Status registers).

The capabilities of the counter/timer are numerous. Up to four port I/O lines can be dedicated as external access lines for each counter/timer: counter input, gate input, trigger input, and counter/timer output. Three different counter/timer output duty cycles are available: pulse, one-shot, or square-wave. The operation of the counter/timer can be programmed as either retriggerable or nonretriggerable. With these and other options, most counter/timer applications are covered.

78536 CIO

There are five registers (Master Interrupt Control register, three Interrupt Vector registers, and the Current Vector register) associated with the interrupt logic. In addition, the ports' Command and Status registers and the counter/timers' Command and Status registers include bits associated with the interrupt logic. Each of these registers contains three bits for interrupt control and status: Interrupt Pending (IP), Interrupt Under Service (IUS), and Interrupt Enable (IE).



### Figure 6. Counter/Timer Block Diagram



### **Functional Description**

The following describes the functions of the ports, pattern-recognition logic, counter/timers, and interrupt logic.

I/O Port Operations. Of the CIO's three I/O ports, two (Ports A and B) are generalpurpose, and the third (Port C) is a specialpurpose 4-bit port. Ports A and B can be configured as input, output, or bidirectional ports with handshake. (Four different handshakes are available.) They can also be linked to form a single 16-bit port. If they are not used as ports with handshake, they provide 16 input or output bits with the data direction programmable on a bit-by-bit basis. Port B also provides access for Counter/Timers 1 and 2. In all configurations. Ports A and B can be programmed to recognize specific data patterns and to generate interrupts when the pattern is encountered.

The four bits of Port C provide the handshake lines for Ports A and B when required. A REQUEST/WAIT line can also be provided so that CIO transfers can be synchronized with DMAs or CPUs. Any Port C bits not used for handshake or REQUEST/WAIT can be used as input or output bits (individually data-direction programmable) or external access lines for Counter/Timer 3. Port C does not contain any pattern-recognition logic. It is, however, capable of bit-addressable writes. With this feature, any combination of bits can be set and/or cleared while the other bits remain undisturbed without first reading the register.

Bit Port Operations. In bit port operations, the port's Data Direction register specifies the direction of data flow for each bit. A 1 specifies an input bit, and a 0 specifies an output bit. If bits are used as I/O bits for a counter/timer, they should be set as input or output, as required.

The Data Path Polarity register provides the capability of inverting the data path. A 1 specifies inverting, and a 0 specifies non-inverting. All discussions of the port operations assume that the path is noninverting.

The value returned when reading an input bit reflects the state of the input just prior to the read. A l's catcher can be inserted into the input data path by programming a l to the corresponding bit position of the port's Special I/O Control register. When a l is detected at the l's catcher input, its output is set to l until it is cleared. The l's catcher is cleared by writing a 0 to the bit. In all other cases, attempted writes to input bits are ignored.

When Ports A and B include output bits, reading the Data register returns the value being output. Reads of Port C return the state of the pin. Outputs can be specified as opendrain by writing a 1 to the corresponding bit of the port's Special I/O Control register. Port C has the additional feature of bit-addressable writes. When writing to Port C, the four most significant bits are used as a write protect mask for the least significant bits (0-4, 1-5, 2-6, and 3-7). If the write protect bit is written with a 1, the state of the corresponding output bit is not changed.

Ports with Handshake Operation. Ports A and B can be specified as 8-bit input, output, or bidirectional ports with handshake. The CIO provides four different handshakes for its ports: Interlocked, Strobed, Pulsed, and 3-Wire. When specified as a port with handshake, the transfer of data into and out of the port and interrupt generation is under control of the handshake logic. Port C provides the handshake lines as shown in Table 1. Any Port C lines not used for handshake can be used as simple I/O lines or as access lines for Counter/Timer 3.

When Ports A and B are configured as ports with handshake, they are double-buffered. This allows for more relaxed interrupt service routine response time. A second byte can be input to or output from the port before the interrupt for the first byte is serviced. Normally, the Interrupt Pending (IP) bit is set and an interrupt is generated when data is shifted into the Input register (input port) or out of the Output register (output port). For input and output ports, the IP is automatically cleared when the data is read or written. In bidirectional ports, IP is cleared only by command.

When the Interrupt on Two Bytes (ITB) control bit is set to 1, interrupts are generated only when two bytes of data are available to be read or written. This allows a minimum of 16 bits of information to be transferred on each interrupt. With ITB set, the IP is not automatically cleared until the second byte of data is read or written.

When the Single Buffer (SB) bit is set to 1, the port acts as if it is only single-buffered. This is useful if the handshake line must be stopped on a byte-by-byte basis.

Ports A and B can be linked to form a 16-bit port by programming a 1 in the Port Link Control (PLC) bit. In this mode, only Port A's Handshake Specification and Command and Status registers are used. Port B must be specified as a bit port. When linked, only Port A has pattern-match capability. Port B's pattern-match capability must be disabled. Also, when the ports are linked, Port B's Data register must be read or written before Port A's.

When a port is specified as a port with handshake, the type of port it is (input, output, or bidirectional) determines the direction of data flow. The data direction for the bidirectional port is determined by a bit in Port C (Table 1) In all cases, the contents of the Data Direction register are ignored. The contents of the Special I/O Control register apply only to output bits (3-state or open-drain). Inputs may not have I's catchers; therefore, those bits in the Special I/O Control register are ignored. Port C lines used for handshake should be programmed as inputs. The handshake specification overrides Port C's Data Direction register for bits that must be outputs. The contents of Port C's Data Path Polarity register still apply.

78536 CIO

Interlocked Handshake. In the Interlocked Handshake mode, the action of the CIO must be acknowledged by the external device before the next action can take place. Figure 7 shows timing for Interlocked Handshake. An output port does not indicate that new data is available until the external device indicates it is ready for the data. Similarly, an input port does not indicate that it is ready for new data until the data source indicates that the previous byte of the data is no longer available, thereby acknowledging the input port's acceptance of the last byte. This allows the CIO to interface directly to the port of a Z8 microcomputer, a UPC, an FIO, an FIFO, or to another CIO port with no external logic.

A 4-bit deskew timer can be inserted in the Data Available ( $\overline{DAV}$ ) output for output ports. As data is transferred to the Buffer register, the deskew timer is triggered. After the number of PCLK cycles specified by the

| Port A/B Configuration                                                          | PC3                        | PC <sub>2</sub> | PC1                        | PC0          |
|---------------------------------------------------------------------------------|----------------------------|-----------------|----------------------------|--------------|
| Ports A and B: Bit Ports                                                        | Bit I/O                    | Bit I/O         | Bit I/O                    | Bit I/O      |
| Port A: Input or Output Port<br>(Interlocked, Strobed, or Pulsed<br>Handshake)* | RFD or DAV                 | ACKIN           | REQUEST/WAIT<br>or Bit I/O | Bit I/O      |
| Port B: Input or Output Port<br>(Interlocked, Strobed, or Pulsed<br>Handshake)* | REQUEST/WAIT<br>or Bit I/O | Bit I/O         | RFD or DAV                 | ACKIN        |
| Port A or B: Input Port (3-Wire<br>Handshake)                                   | RFD (Output)               | DAV (Input)     | REQUEST/WAIT<br>or Bit I/O | DAC (Output) |
| Port A or B: Output Port (3-Wire<br>Handshake)                                  | DAV (Output)               | DAC (Input)     | REQUEST/WAIT<br>or Bit I/O | RFD (Input)  |
| Port A or B: Bidirectional Port<br>(Interlocked or Strobed Handshake)           | RFD or DAV                 | ACKIN           | REQUEST/WAIT<br>or Bit I/O | IN/OUT       |

\*Both Ports A and B can be specified input or output with Interlocked, Strobed, or Pulsed Handshake at the same time if neither uses REQUEST/WAIT.

### Table 1. Port C Bit Utilization



deskew timer time constant plus one,  $\overline{DAV}$  is allowed to go Low. The deskew timer therefore guarantees that the output data is valid for a specified minimum amount of time before  $\overline{DAV}$ goes Low. Deskew timers are available for output ports independent of the type of handshake employed.

**Strobed Handshake.** In the Strobed Handshake mode, data is "strobed" into or out of the port by the external logic. The falling edge of the Acknowledge Input ( $\overline{ACKIN}$ ) strobes data into or out of the port. Figure 7 shows timing for the Strobed Handshake. In contrast to the Interlocked handshake, the signal indicating the port is ready for another data transfer operates independently of the  $\overline{ACKIN}$ input. It is up to the external logic to ensure that data overflows or underflows do not occur.

**3-Wire Handshake.** The 3-Wire Handshake is designed for the situation in which one output port is communicating with many input ports simultaneously. It is essentially the same as the Interlocked Handshake, except that two signals are used to indicate if an input port is ready for new data or if it has accepted the present data. In the 3-Wire Handshake (Figure 8), the rising edge of one status line indicates that the port is ready for data, and the rising edge of another status line indicates that the data has been accepted. With the 3-Wire Handshake, the output lines of many input ports can be bussed together with open-drain drivers; the

output port knows when all the ports have accepted the data and are ready. This is the same handshake as is used on the IEEE-488 bus. Because this handshake requires three lines, only one port (either A or B) can be a 3-Wire Handshake port at a time. The 3-Wire Handshake is not available in the bidirectional mode. Because the port's direction can be changed under software control, however, bidirectional IEEE-488-type transfers can be performed.

Pulsed Handshake. The Pulsed Handshake (Figure 9) is designed to interface to mechanical-type devices that require data to be held for long periods of time and need relatively wide pulses to gate the data into or out of the device. The logic is the same as the Interlocked Handshake mode, except that an internal counter/timer is linked to the handshake logic. If the port is specified in the input mode, the timer is inserted in the  $\overline{\text{ACKIN}}$  path. The external **ACKIN** input triggers the timer and its output is used as the Interlocked Handshake's normal acknowledge input. If the port is an output port, the timer is placed in the Data Available ( $\overline{DAV}$ ) output path. The timer is triggered when the normal Interlocked Handshake DAV output goes Low and the timer output is used as the actual DAV output. The counter/timer maintains all of its normal capabilities. This handshake is not available to bidirectional ports.



Figure 7. Interlocked and Strobed Handshakes





**REQUEST/WAIT Line Operation.** Port C can be programmed to provide a status signal output in addition to the normal handshake lines for either Port A or B when used as a port with handshake. The additional signal is either a REQUEST or WAIT signal. The REQUEST signal indicates when a port is ready to perform a data transfer via the CPU interface. It is intended for use with a DMA-type device. The WAIT signal provides synchronization for transfers with a CPU. Three bits in the Port Handshake Specification register provide controls for the REQUEST/WAIT logic. Because the extra Port C line is used, only one port can be specified as a port with a handshake and a REQUEST/WAIT line. The other port must be a bit port.

Operation of the REQUEST line is modified by the state of the port's Interrupt on Two Bytes (ITB) control bit. When ITB is 0, the REQUEST line goes active as soon as the CIO is ready for a data transfer. If ITB is 1, REQUEST does not go active until two bytes can be transferred. REQUEST stays active as long as a byte is available to be read or written.

The SPECIAL REQUEST function is reserved for use with bidirectional ports only. In this case, the REOUEST line indicates the status of the register not being used in the data path at that time. If the IN/OUT line is High, the **REQUEST** line is High when the Output register is empty. If IN/OUT is Low, the **REQUEST** line is High when the Input register is full.

Pattern-Recognition Logic Operation. Both Ports A and B can be programmed to generate interrupts when a specific pattern is recognized at the port. The pattern-recognition logic is independent of the port application, thereby allowing the port to recognize patterns in all of its configurations. The pattern can be independently specified for each bit as 1, 0, rising edge, falling edge, or any transition. Individual bits may be masked off. A patternmatch is defined as the simultaneous satisfaction of all nonmasked bit specifications in the AND mode or the satisfaction of any nonmasked bit specifications in either of the OR or **OR-Priority Encoded Vector modes.** 

78536 CIO





The pattern specified in the Pattern Definition register assumes that the data path is programmed to be noninverting. If an input bit in the data path is programmed to be inverting, the pattern detected is the opposite of the one specified. Output bits used in the patternmatch logic are internally sampled before the invert/noninvert logic.



Bit Port Pattern-Recognition Operations. During bit port operations, pattern-recognition may be performed on all bits, including those used as I/O for the counter/timers. The input to the pattern-recognition logic follows the value at the pins (through the invert/noninvert logic) in all cases except for simple inputs with l's catchers. In this case, the output of the l's catcher is used. When operating in the AND or OR mode, it is the transition from a nomatch to a match state that causes the interrupt. In the "OR" mode, if a second match occurs before the first match goes away, it does not cause an interrupt. Since a match condition only lasts a short time when edges are specified, care must be taken to avoid losing a match condition. Bit ports specified in the OR-Priority Encoded Vector mode generate interrupts as long as any match state exists. A transition from a no-match to a match state is not required.

The pattern-recognition logic of bit ports operates in two basic modes: transparent and latched. When the Latch on Pattern Match (LPM) bit is set to 0 (Transparent mode), the interrupt indicates that a specified pattern has occurred, but a read of the Data register does not necessarily indicate the state of the port at the time the interrupt was generated. In the Latched mode (LPM = 1), the state of all the port inputs at the time the interrupt was generated is latched in the input register and held until IP is cleared. In all cases, the PMF indicates the state of the port at the time it is read.

If a match occurs while IP is already set, an error condition exists. If the Interrupt On Error bit (IOE) is 0, the match is ignored. However, if IOE is 1 after the first IP is cleared, it is automatically set to 1 along with the Interrupt Error (ERR) flag. Matches occurring while ERR is set are ignored. ERR is cleared when the corresponding IP is cleared.

When a pattern-match is present in the OR-Priority Encoded Vector mode, IP is set to 1. The IP cannot be cleared until a match is no longer present. If the interrupt vector is allowed to include status, the vector returned during Interrupt Acknowledge indicates the highest priority bit matching its specification at the time of the Acknowledge cycle. Bit 7 is the highest priority and bit 0 is the lowest. The bit initially causing the interrupt may not be the one indicated by the vector if a higher priority bit matches before the Acknowledge. Once the Acknowledge cycle is initiated, the vector is frozen until the corresponding IP is cleared. Where inputs that cause interrupts might change before the interrupt is serviced, the 1's catcher can be used to hold the value. Because a no-match to match transition is not required, the source of the interrupt must be cleared before IP is cleared or else a second interrupt is generated. No error detection is performed in this mode, and the Interrupt On Error bit should be set to 0.

Ports with Handshake Pattern-Recognition **Operation**. In this mode, the handshake logic normally controls the setting of IP and, therefore, the generation of interrupt requests. The pattern-match logic controls the Pattern-Match Flag (PMF). The data is compared with the match pattern when it is shifted from the Buffer register to the Input register (input port) or when it is shifted from the Output register to the Buffer register (output port). The pattern match logic can override the handshake logic in certain situations. If the port is programmed to interrupt when two bytes of data are available to be read or written, but the first byte matches the specified pattern, the pattern-recognition logic sets IP and generates an interrupt. While PMF is set, IP cannot be cleared by reading or writing the data registers. IP must be cleared by command. The input register is not emptied while IP is set, nor is the output register filled until IP is cleared.

If the Interrupt on Match Only (IMO) bit is set, IP is set only when the data matches the pattern. This is useful in DMA-type application when interrupts are required only after a block of data is transferred.

**Counter/Timer Operation.** The three independent 16-bit counter/timers consist of a presettable 16-bit down counter, a 16-bit Time

Constant register, a 16-bit Current Counter register, an 8-bit Mode Specification register, an 8-bit Command and Status register, and the associated control logic that links these registers.

| $C/T_1$ | C/T <sub>2</sub>     | $C/T_3$                                                                   |
|---------|----------------------|---------------------------------------------------------------------------|
| PB 4    | PB 0                 | PC 0                                                                      |
| PB 5    | PB 1                 | PC 1                                                                      |
| PB 6    | PB 2                 | PC 2                                                                      |
| PB 7    | PB 3                 | PC 3                                                                      |
|         | PB 4<br>PB 5<br>PB 6 | PB 4         PB 0           PB 5         PB 1           PB 6         PB 2 |

### Table 2. Counter/Timer External Access

The flexibility of the counter/timers is enhanced by the provision of up to four lines per counter/timer (counter input, gate input, trigger input, and counter/timer output) for direct external control and status. Counter/ Timer 1's external I/O lines are provided by the four most significant bits of Port B. Counter/Timer 2's are provided by the four least significant bits of Port B. Counter/Timer 3's external I/O lines are provided by the four bits of Port C. The utilization of these lines (Table 2) is programmable on a bit-by-bit basis via the Counter/Timer Mode Specification recisters.

When external counter/timer I/O lines are to be used, the associated port lines must be vacant and programmed in the proper data direction. Lines used for counter/timer I/O have the same characteristics as simple input lines. They can be specified as inverting or noninverting; they can be read and used with the pattern-recognition logic. They can also include the l's catcher input.

78536 CIO

Counter/Timers 1 and 2 can be linked internally in three different ways. Counter/Timer 1's output (inverted) can be used as Counter/ Timer 2's trigger, gate, or counter input. When linked, the counter/timers have the same capabilities as when used separately. The only restriction is that when Counter/Timer 1 drives Counter/Timer 2's count input, Counter/Timer 2 must be programmed with its external count input disabled.

There are three duty cycles available for the timer/counter output: pulse, one-shot, and square-wave. Figure 10 shows the counter/ timer waveforms. When the Pulse mode is specified, the output goes High for one clock cycle, beginning when the down-counter leaves the count of 1. In the One-Shot mode, the output goes High when the counter/timer is triggered and goes Low when the downcounter reaches 0. When the square-wave output duty cycle is specified, the counter/timer goes through two full sequences for each cycle. The initial trigger causes the downcounter to be loaded and the normal count-







Z8536 CIO

down sequence to begin. If a 1 count is detected on the down-counter's clocking edge, the output goes High and the time constant value is reloaded. On the clocking edge, when both the down-counter and the output are 1's, the output is pulled back Low.

The Continuous/Single Cycle (C/SC) bit in the Mode Specification register controls operation of the down-counter when it reaches terminal count. If  $C/\overline{SC}$  is 0 when a terminal count is reached, the countdown sequence stops. If the  $C/\overline{SC}$  bit is 1 each time the countdown counter reaches 1, the next cycle causes the time constant value to be reloaded. The time constant value may be changed by the CPU, and on reload, the new time constant value is loaded.

Counter/timer operations require loading the time constant value in the Time Constant register and initiating the countdown sequence by loading the down-counter with the time constant value. The Time Constant register is accessed as two 8-bit registers. The registers are readable as well as writable, and the access order is irrelevant. A 0 in the Time Constant register specifies a time constant of 65,536. The down-counter is loaded in one of three ways: by writing a 1 to the Trigger Command Bit (TCB) of the Command and Status register, on the rising edge of the external trigger input, or, for Counter/Timer 2 only, on the rising edge of Counter/Timer 1's internal output if the counters are linked via the trigger input. The TCB is write-only, and read always returns 0.

Once the down-counter is loaded, the countdown sequence continues toward terminal count as long as all the counter/timers' hardware and software gate inputs are High. If any of the gate inputs goes Low (0), the countdown halts. It resumes when all gate inputs are 1 again.

The reaction to triggers occurring during a countdown sequence is determined by the state of the Retrigger Enable Bit (REB) in the Mode Specification register. If REB is 0, retriggers are ignored and the countdown continues normally. If REB is 1, each trigger causes the down-counter to be reloaded and the countdown sequence starts over again. If the output is programmed in the Square-Wave mode, retrigger causes the sequence to start over from the initial load of the time constant.

The rate at which the down-counter counts is determined by the mode of the counter/timer. In the Timer mode (the External Count Enable [ECE] bit is 0), the down-counter is clocked internally by a signal that is half the frequency of the PCLK input to the chip. In the Counter mode (ECE is 1), the down-counter is decremented on the rising edge of the counter/ timer's counter input.

Each time the counter reaches terminal count, its Interrupt Pending (IP) bit is set to 1, and if interrupts are enabled (IE = 1), an interrupt is generated. If a terminal count occurs while IP is already set, an internal error flag is set. As soon as IP is cleared, it is forced to 1 along with the Interrupt Error (ERR) flag. Errors that occur after the internal flag is set are ignored.

The state of the down-counter can be determined in two ways: by reading the contents of the down-counter via the Current Count register or by testing the Count In Progress (CIP) status bit in the Command and Status register. The CIP status bit is set when the down-counter is loaded: it is reset when the down-counter reaches 0. The Current Count register is a 16-bit register, accessible as two 8-bit registers, which mirrors the contents of the down-counter. This register can be read anytime. However, reading the register is asynchronous to the counter's counting, and the value returned is valid only if the counter is stopped. The down-counter can be reliably read "on the fly" by the first writing of a 1 to the Read Counter Control (RCC) bit in the counter/timer's Command and Status register. This freezes the value in the Current Count register until a read of the least significant byte is performed.

**Interrupt Logic Operation.** The CIO has five potential sources of interrupts: the three counter/timers and Ports A and B. The

priorities of these sources are fixed in the following order: Counter/Timer 3, Port A, Counter/Timer 2, Port B, and Counter/Timer 1. Since the counter/timers all have equal capabilities and Ports A and B have equal capabilities, there is no adverse impact from the relative priorities.

The CIO interrupt priority, relative to other components within the system, is determined by an interrupt daisy chain. Two pins, Interrupt Enable In (IEI) and Interrupt Enable Out (IEO), provide the input and output necessary to implement the daisy chain. When IEI is pulled Low by a higher priority device, the CIO cannot request an interrupt of the CPU. The following discussion assumes that the IEI line is High.

Each source of interrupt in the CIO contains three bits for the control and status of the interrupt logic: an Interrupt Pending (IP) status bit, an Interrupt Under Service (IUS) status bit, and an Interrupt Enable (IE) control bit. IP is set when an event requiring CPU intervention occurs. The setting of IP results in forcing the Interrupt (INT) output Low, if the associated IE is 1.

The IUS status bit is set as a result of the Interrupt Acknowledge cycle by the CPU and is set only if its IP is of highest priority at the time the Interrupt Acknowledge commences. It can also be set directly by the CPU. Its primary function is to control the interrupt daisy chain. When set, it disables lower priority sources in the daisy chain, so that lower priority interrupt sources do not request servicing while higher priority devices are being serviced.

The IE bit provides the CPU with a means of masking off individual sources of interrupts. When IE is set to 1, interrupt is generated normally. When IE is set to 0, the IP bit is set when an event occurs that would normally require service; however, the INT output is not forced Low. The Master Interrupt Enable (MIE) bit allows all sources of interrupts within the CIO to be disabled without having to individually set each IE to 0. If MIE is set to 0, all IPs are masked off and no interrupt can be requested or acknowledged. The Disable Lower Chain (DLC) bit is included to allow the CPU to modify the system daisy chain. When the DLC bit is set to 1, the CIO's IEO is forced Low, independent of the state of the CIO or its IEI input, and all lower priority devices' interrupts are disabled.

Z8536 CIO

As part of the Interrupt Acknowledge cycle, the CIO is capable of responding with an 8-bit interrupt vector that specifies the source of the interrupt. The CIO contains three vector registers: one for Port A, one for Port B, and one shared by the three counter/timers. The vector output is inhibited by setting the No. Vector (NV) control bit to 1. The vector output can be modified to include status information to pinpoint more precisely the cause of interrupt. Whether the vector includes status or not is controlled by a Vector Includes Status (VIS) control bit. Each base vector has its own VIS bit and is controlled independently. When MIE = 1, reading the base vector register always includes status, independent of the state of the VIS bit. In this way, all the information obtained by the vector, including status, can be obtained with one additional instruction when VIS is set to 0. When MIE = 0, reading the vector register returns the unmodified base vector so that it can be verified. Another register, the Current Vector register, allows use of the CIO in a polled environment. When read, the data returned is the same as the interrupt vector that would be output in an acknowledge, based on the highest priority IP set. If no unmasked IPs are set, the value  $FF_H$  is returned. The Current Vector register is read-only.



### Programming

The data registers within the CIO are directly accessed by address lines  $A_0$  and  $A_1$ (Table 3). All other internal registers are accessed by the following two-step sequence, with the address lines specifying a control operation. First, write the address of the target register to an internal 6-bit Pointer Register; then read from or write to the target register. The Data registers can also be accessed by this method.

An internal state machine determines if accesses with  $A_0$  and  $A_1$  equalling 1 are to the Pointer Register or to an internal control register (Figure 11). Following any control read operation, the state machine is in State 0 (the next control access is to the Pointer Register). This can be used to force the state machine into a known state. Control reads in State 0 return the contents of the last register

| A | A <sub>0</sub> | Register               | _ |
|---|----------------|------------------------|---|
| 0 | 0              | Port C's Data Register | _ |
| 0 | 1              | Port B's Data Régister |   |
| 1 | 0              | Port A's Data Register |   |
| 1 | 1              | Control Registers      |   |

Table 3. Register Selection

pointed to. Therefore, a register can be read continuously without writing to the Pointer. While the CIO is in State 1 (next control access is to the register pointed to), many internal operations are suspended—no IPs are set and internal status is frozen. Therefore, to minimize interrupt latency and to allow continuous status updates, the CIO should not be left in State 1.

The CIO is reset by forcing  $\overline{RD}$  and  $\overline{WR}$  Low simultaneously (normally an illegal condition) or by writing a 1 to the Reset bit. Reset disables all functions except a read from or write to the Reset bit; writes to all other bits are ignored, and all reads return  $01_H$ . In this state, all control bits are forced to 0 and may be programmed only after clearing the Reset bit (by writing a 0 to it).



NOTE: State changes occur only when  $A_0 = A_1 = 1$ . No other accesses have effect.

Figure 11. State Machine Operation



### Registers



Figure 12. Master Control Registers











### Data Path Polarity Registers

Addresses: 100010 Port A 101010 Port B 000101 Port C (4 LSBs only) (Read/Write)

DATA PATH POLARITY (DPP) 0 = NON·INVERTING 1 = INVERTING

### **Data Direction Registers**

Addresses: 100011 Port A 101011 Port B 000110 Port C (4 LSBs only) (Read/Write)



DATA DIRECTION (DD) 0 = OUTPUT BIT 1 = INPUT BIT

### Special I/O Control Registers

Addresses: 100100 Port A 101100 Port B 000111 Port C (4 LSBs only) (Read/Write)



SPECIAL INPUT/OUTPUT (SIO) 0 = NORMAL INPUT OR OUTPUT 1 = OUTPUT WITH OPEN DRAIN OR INPUT WITH 1'S CATCHER



### Port Data Registers Addresses: 001101 Port A\* 001110 Port B\* (Read/Write)

D<sub>7</sub> D<sub>6</sub> D<sub>5</sub> D<sub>4</sub> D<sub>3</sub> D<sub>2</sub> D<sub>1</sub> D<sub>0</sub>

\*These registers can be addressed directly.

### Port C Data Register

Address: 001111\* (Read/Write)





4 MSBs 0 = WRITING OF CORRESPONDING LSB ENABLED 1 = WRITING OF CORRESPONDING LSB INHIBITED (READ RETURNS 1)

Figure 15. Port Data Registers















Figure 17. Counter/Timer Registers (Continued)



### **Interrupt Vector Register Current Vector Register** Addresses: 000010 Port A Address: 011111 000011 Port B (Read only) 000100 Counter/Timers D7 D6 D5 D4 D3 D2 D1 D0 (Read/Write) INTERRUPT VECTOR BASED ON HIGHEST PRIORITY UNMASKED IP. IN NO INTERRUPT PENDING ALL 1'S OUTPUT. - INTERRUPT VECTOR PORT VECTOR STATUS PRIORITY ENCODED VECTOR MODE: D<sub>3</sub> D<sub>2</sub> D<sub>1</sub> x x x NUMBER OF HIGHEST PRIORITY BIT WITH A MATCH ALL OTHER MODES: D<sub>3</sub> D<sub>2</sub> D<sub>1</sub> ORE IRF PMF NORMAL 0 0 0 ERROR COUNTER/TIMER STATUS D2 D1 C/T 3 C/T 2 C/T 1 ERROR 0 0 1 0 1 0 1

### Figure 18. Interrupt Vector Registers



### **Register Address Summary**

### Main Control Registers

| Address                             |                                  |
|-------------------------------------|----------------------------------|
| (AD <sub>7</sub> -AD <sub>0</sub> ) | Register Name                    |
| 000000XX                            | Master Interrupt Control         |
| 000001XX                            | Master Configuration Control     |
| 000010XX                            | Port A's Interrupt Vector        |
| 000011XX                            | Port B's Interrupt Vector        |
| 000100XX                            | Counter/Timer's Interrupt Vector |
| 000101XX                            | Port C's Data Path Polarity      |
| 000110XX                            | Port C's Data Direction          |
| 000111XX                            | Port C's Special I/O Control     |
|                                     |                                  |

### **Most Often Accessed Registers**

1 .....

### Address

| $(AD_7 - AD_0)$ | Regis | ster  | Name |
|-----------------|-------|-------|------|
| 001000VV        | Dent  | × / - | C    |

| 001000XX | Port A's Command and Status              |
|----------|------------------------------------------|
| 001001XX | Port B's Command and Status              |
| 001010XX | Counter/Timer 1's Control                |
| 001011XX | Counter/Timer 2's Control                |
| 001100XX | Counter/Timer 3's Control                |
| 001101XX | Port A's Data (can be accessed directly) |
| 001110XX | Port B's Data (can be accessed directly) |
| 001111XX | Port C's Data (can be accessed directly) |
|          |                                          |

...

### **Counter/Timer Related Registers**

### Address

### (AD<sub>7</sub>-AD<sub>0</sub>) Register Name

| 010000XX | Counter/Timer 1's Current Count-MSBs |
|----------|--------------------------------------|
| 010001XX | Counter/Timer 1's Current Count-LSBs |
| 010010XX | Counter/Timer 2's Current Count-MSBs |
| 010011XX | Counter/Timer 2's Current Count-LSBs |
| 010100XX | Counter/Timer 3's Current Count-MSBs |
| 010101XX | Counter/Timer 3's Current Count-LSBs |
| 010110XX | Counter/Timer 1's Time Constant-MSBs |
| 010111XX | Counter/Timer 1's Time Constant-LSBs |

### Counter/Timer Related Registers (Continued) Address

| maaross                             |                                      |
|-------------------------------------|--------------------------------------|
| (AD <sub>7</sub> -AD <sub>0</sub> ) | Register Name                        |
| 011000XX                            | Counter/Timer 2's Time Constant-MSBs |
| 011001XX                            | Counter/Timer 2's Time Constant-LSBs |
| 011010 <b>XX</b>                    | Counter/Timer 3's Time Constant-MSBs |
| 011011 <b>XX</b>                    | Counter/Timer 3's Time Constant-LSBs |
| 011100 <b>XX</b>                    | Counter/Timer 1's Mode Specification |
| 011101 <b>XX</b>                    | Counter/Timer 2's Mode Specification |
| 011110 <b>XX</b>                    | Counter/Timer 3's Mode Specification |
| 011111 <b>XX</b>                    | Current Vector                       |
|                                     |                                      |

### Port A Specification Registers

#### Address (AD7-AD0) **Register Name** 100000XX Port A's Mode Specification Port A's Handshake Specification 100001XX Port A's Data Path Polarity 100010XX Port A's Data Direction 100011XX 100100XX Port A's Special I/O Control 100101XX Port A's Pattern Polarity 100110XX Port A's Pattern Transition 100111XX Port A's Pattern Mask

### **Port B Specification Registers**

# Address (AD7-AD0) Register Name 101000XX Port B's Mode Specification 101001XX Port B's Handshake Specification 101010XX Port B's Data Path Polarity 101011XX Port B's Data Direction

| IUIUIIAA | Port D's Data Direction      |
|----------|------------------------------|
| 101100XX | Port B's Special I/O Control |
| 101101XX | Port B's Pattern Polarity    |
| 101110XX | Port B's Pattern Transition  |
| 101111XX | Port B's Pattern Mask        |



### Timing

**Read Cycle.** At the beginning of a read cycle, the CPU places an address on the address bus. Bits  $A_0$  and  $A_1$  specify a CIO register; the remaining address bits and status information are combined and decoded to generate a Chip Enable ( $\overline{CE}$ ) signal that selects the CIO. When Read ( $\overline{RD}$ ) goes Low, data from the specified register is gated onto the data bus. Write Cycle. At the beginning of a write cycle, the CPU places an address on the data bus. Bits  $A_0$  and  $A_1$  specify a CIO register; the remaining address bits and status information are combined and decoded to generate a Chip Enable ( $\overline{CE}$ ) signal that selects the CIO. When  $\overline{WR}$  goes Low, data placed on the bus by the CPU is strobed into the specified CIO register.



Figure 19. Read Cycle Timing

Figure 20. Write Cycle Timing

**Interrupt Acknowledge.** The CIO pulls its Interrupt Request (INT) line Low, requesting interrupt service from the CPU, if an Interrupt Pending (IP) bit is set and interrupts are enabled. The CPU responds with an Interrupt Acknowledge cycle. When Interrupt Acknowledge (INTACK) goes true and the IP is set, the CIO forces Interrupt Enable Out (IEO) Low, disabling all lower priority devices in the interrupt daisy chain. If the CIO is the highest priority device requesting service (IEI is High), it places its interrupt vector on the data bus and sets the Interrupt Under Service (IUS) bit when Read  $(\overline{\text{RD}})$  goes Low.







### **Absolute Maximum Rating**

| Voltages on all inputs and outputs |
|------------------------------------|
| with respect to GND0.3 V to +7.0 V |
| Operating Ambient                  |
| Temperature As Specified in        |
| Ordering Information               |
| Storage Temperature65°C to +150°C  |

### **Standard Test Conditions**

The characteristics below apply for the following standard test conditions, unless otherwise noted. All voltages are referenced to GND. Positive current flows into the referenced pin. Standard conditions are as follows:



Figure 22. Standard Test Load

### **DC Characteristics**

Stresses greater than those listed under Absolute Maximum Ratings may cause permanent damage to the device. This is a stress rating only; operation of the device at any condition above those indicated in the operational sections of these specifications is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

- $\blacksquare$  +4.75 V  $\leq$  V\_{CC}  $\leq$  +5.25 V
- $\blacksquare$  GND = 0 V
- T<sub>A</sub> as specified in Ordering Information

All ac parameters assume a load capacitance of 50 pF max.



Figure 23. Open-Drain Test Load

| Symbol          | Parameter                      | Min  | Μαχ                  | Unit | Condition                     |
|-----------------|--------------------------------|------|----------------------|------|-------------------------------|
| V <sub>IH</sub> | Input High Voltage             | 2.0  | V <sub>CC</sub> +0.3 | V    |                               |
| V <sub>IL</sub> | Input Low Voltage              | -0.3 | 0.8                  | v    |                               |
| V <sub>OH</sub> | Output High Voltage            | 2.4  |                      | v    | $I_{OH} = -250 \ \mu A$       |
| V <sub>OL</sub> | Output Low Voltage             |      | 0.4                  | v    | $I_{OL} = +2.0 \text{ mA}$    |
|                 |                                |      | 0.5                  | v    | $I_{OL} = +3.2 \text{ mA}$    |
| $I_{IL}$        | Input Leakage                  |      | ±10.0                | μA   | $0.4 \leq V_{IN} \leq +2.4 V$ |
| I <sub>OL</sub> | Output Leakage                 |      | ±10.0                | μĀ   | $0.4 \le V_{OUT} \le +2.4 V$  |
| I <sub>CC</sub> | V <sub>CC</sub> Supply Current |      | 250                  | mĀ   |                               |

 $V_{\rm CC}$  = 5 V  $\pm$  5% unless otherwise specified, over specified temperature range.

### Capacitance

| Symbol           | Parameter                 | Min | Max | Unit | Test Condition     |
|------------------|---------------------------|-----|-----|------|--------------------|
| C <sub>IN</sub>  | Input Capacitance         |     | 10  | pF   | Unmeasured Pins    |
| C <sub>OUT</sub> | Output Capacitance        |     | 15  | pF   | Returned to Ground |
| $C_{I/O}$        | Bidirectional Capacitance |     | 20  | pF   |                    |

f = 1 MHz, over specified temperature range.

### **CPU Interface Timing**

| Number | Symbol           | Parameter                                        | Min   | Μαχ  | Units | Notes* |
|--------|------------------|--------------------------------------------------|-------|------|-------|--------|
| 1      | TcPC             | PCLK Cycle Time                                  | 250   | 4000 | ns    |        |
| 2      | TwPCh            | PCLK Width (High)                                | 105   | 2000 | ns    |        |
| 3      | TwPCl            | PCLK Width (Low)                                 | 105   | 2000 | ns    |        |
| 4      | TrPC             | PCLK Rise Time                                   |       | 20   | ns    |        |
| 5—     | -TfPC            | – PCLK Fall Time –                               |       | 20   | ns    |        |
| 6      | TsIA(PC)         | INTACK to PCLK † Setup Time                      | 100   |      | ns    |        |
| 7      | ThIA(PC)         | INTACK To PCLK † Hold Time                       | 0     |      | ns    |        |
| 8      | TsIA(RD)         | INTACK to RD   Setup Time                        | 200   |      | ns    | 1      |
| 9      | ThIA(RD)         | INTACK to RD † Hold Time                         | 0     |      | ns    |        |
| 10     | -TsIA(WR)        | - INTACK to WR & Setup Time                      |       |      | ns    |        |
| 11     | ThIA(WR)         | INTACK to WR   Hold Time                         | 0     |      | ns    |        |
| 12     | TsA(RD)          | Address to $\overline{\mathrm{RD}}$ ↓ Setup Time | 80    |      | ns    |        |
| 13     | Th <b>A</b> (RD) | Address to RD † Hold Time                        | 0     |      | ns    |        |
| 14     | TsA(WR)          | Address to WR   Setup Time                       | 80    |      | ns    |        |
| 15—    | - ThA(WR)        | - Address to WR † Hold Time                      | 0 -   |      | ns    |        |
| 16     | TsCEl(RD)        | CE Low to RD ↓ Setup Time                        | 0     |      | ns    | 1      |
| 17     | TsCEh(RD)        | CE High to RD   Setup Time                       | 100   |      | ns    | 1      |
| 18     | ThCE(RD)         | CE to RD † Hold Time                             | 0     |      | ns    | 1      |
| 19     | TsCEl(WR)        | CE Low to WR   Setup Time                        | 0     |      | ns    |        |
| 20     | -TsCEh(WR)-      | - CE High to WR   Setup Time                     | 100 - |      | ns    |        |
| 21     | ThCE(WR)         | CE to WR † Hold Time                             | 0     |      | ns    |        |
| 22     | TwRDl            | RD Low Width                                     | 390   |      | ns    | 1      |
| 23     | TdRD(DRA)        | RD ↓ to Read Data Active Delay                   | 0     |      | ns    |        |
| 24     | TdRDf(DR)        | RD ↓ to Read Data Valid Delay                    |       | 255  | ns    |        |
| 25     | - TdRDr(DR)      | – RD † to Read Data Not Valid Delay ——           | 0 -   |      | ns    |        |
| 26     | TdRD(DRz)        | RD † to Read Data Float Delay                    |       | 70   | ns    | 2      |
| 27     | TwWRl            | WR Low Width                                     | 390   |      | ns    |        |
| 28     | TsDW(WR)         | Write Data to ₩R ↓ Setup Time                    | . 0   |      | ns    |        |
| 29     | ThDW(WR)         | Write Data to WR † Hold Time                     | 0     |      | ns    |        |
| 30     | Trc              | Valid Access Recovery Time                       | 1000* |      | ns    | 3      |

1. Parameter does not apply to Interrupt Acknowledge transactions. 2. Float delay is measured to the time when the output has

changed 0.5 V with minimum ac load and maximum dc load. 3. Trc is  $1\mu S$  or 3 TcPC, whichever is longer.



### **CPU Interface Timing**





### Interrupt Timing

| Number | Symbol     | Parameter                                    | Min | Μαχ | Units        | Notes* |
|--------|------------|----------------------------------------------|-----|-----|--------------|--------|
| 31     | TdPM(INT)  | Pattern Match to INT Delay (Bit Port)        |     | 2   | TcPC .       |        |
| 32     | TdACK(INT) | ACKIN to INT Delay (Port with Handshake)     |     | 10  | + ns<br>TcPC | 4      |
| 33     | TdCI(INT)  | - Counter Input to INT Delay (Counter Mode)— |     | 2   | + ns<br>TcPC |        |
| 34     | TdPC(INT)  | PCLK to INT Delay (Timer Mode)               |     | 3   | + ns<br>TcPC |        |
|        |            |                                              |     | •   | + ns         |        |

The delay is from DAV 4 for 3-Wire Input Handshake. The delay is from DAC 1 for 3-Wire Output Handshake.



| Number | Symbol         | Parameter                                                           | Min | Μαχ   | Units | Notes* |
|--------|----------------|---------------------------------------------------------------------|-----|-------|-------|--------|
| 35     | TsIA(RDA)      | INTACK to RD ↓ (Acknowledge) Setup Time                             | 350 |       | ns    | 5      |
| 36     | TwRDA          | RD (Acknowledge Width)                                              | 350 |       | ns    |        |
| 37     | TdRDA(DR)      | RD ↓ (Acknowledge) to Read Data Valid Delay                         |     | 255   | ns    |        |
| 38     | TdIA(IEO)      | INTACK   to IEO   Delay                                             |     | 350   | ns    | 5      |
| 39     | - TdIEI(IEO) — | – IEI to IEO Delay <del>– – – – – – – – – – – – – – – – – – –</del> |     | - 150 | ns    | 5      |
| 40     | TsIEI(RDA)     | IEI to $\overline{	ext{RD}}$   (Acknowledge) Setup Time             | 100 |       | ns    | 5      |
| 41     | ThIEI(RDA)     | IEI to RD † (Acknowledge) Hold Time                                 | 100 |       | ns    |        |
| 42     | TdRDA(INT)     | RD ↓ (Acknowledge) to INT † Delay                                   |     | 600   | ns    |        |

### Interrupt Acknowledge Timing

NOTES:

5. The parameters for the devices in any particular daisy chain must meet the following constraint: The delay from INTACK 1 to RD 1 must be greater than the sum of TdIA(IEO) for the highest priority peripheral, TsIEI(RDA) for the lowest priority

peripheral, and  $\ensuremath{\mathsf{TdIEI}}(\ensuremath{\mathsf{IEO}})$  for each peripheral separating them in the chain.

Z8536 CIO

\*Timings are preliminary and subject to change.





### Handshake Timing

| Number | Symbol       | Parameter                                                                | Min      | Max | Units    | Notes*   |
|--------|--------------|--------------------------------------------------------------------------|----------|-----|----------|----------|
| 1      | TsDI(ACK)    | Data Input to ACKIN   Setup Time                                         | 0        |     | ns       |          |
| 2      | ThDI(ACK)    | Data Input to ACKIN ↓ Hold Time—<br>Strobed Handshake                    |          |     | ns       |          |
| 3      | TdACKf(RFD)  | ACKIN ↓ to RFD ↓ Delay                                                   | 0        |     | ns       |          |
| 4      | TwACK1       | ACKIN Low Width—Strobed Handshake                                        |          |     | ns       |          |
| 5      | -TwACKh      | - ACKIN High Width—Strobed Handshake                                     |          |     | ns       | <u> </u> |
| 6      | TdRFDr(ACK)  | RFD † to ACKIN ↓ Delay                                                   | 0        |     | ns       |          |
| 7      | TsDO(DAV)    | Data Out to DAV   Setup Time                                             | 25       |     | ns       | 1        |
| 8      | TdDAVf(ACK)  | DAV I to ACKIN I Delay                                                   | 0        |     | ns       |          |
| 9      | ThDO(ACK)    | Data Out to ACKIN ↓ Hold Time                                            | 2        |     | TcPC     |          |
| 10     | -TdACK(DAV)  | — ACKIN 1 to DAV 1 Delay ————                                            | <u> </u> |     | — TcPC — |          |
| 11     | ThDI(RFD)    | Data Input to RFD ↓ Hold Time—<br>Interlocked Handshake                  | 0        |     | ns       |          |
| 12     | TdRFDf(ACK)  | RFD ↓ to ACKIN † Delay—<br>Interlocked Handshake                         | 0        |     | ns       |          |
| 13     | TdACKr(RFD)  | ACKIN † (DAV †) to RFD † Delay—<br>Interlocked and 3-Wire<br>Handshake   | 0        |     | ns       |          |
| 14     | TdDAVr(ACK)  | DAV t to ACKIN t (RFD t)—Interlocked<br>and 3-Wire Handshake             | 0        |     | ns       |          |
| 15     | TdACK(DAV)   | – ACKIN † (RFD †) to DAV   Delay—<br>Interlocked and 3-Wire<br>Handshake | — 0 —    |     | ns       |          |
| 16     | TdDAVIf(DAC) | DAV   to DAC † Delay—Input<br>3-Wire Handshake                           | 0        |     | ns       |          |
| 17     | ThDI(DAC)    | Data Input to DAC † Hold Time—<br>3-Wire Handshake                       | 0        |     | ns       |          |
| 18     | TdDACOr(DAV) | DAC † to DAV † Delay—Input<br>3-Wire Handshake                           | 0        |     | ns       |          |
| 19     | TdDAVIr(DAC) | DAV † to DAC ↓ Delay—Input<br>3-Wire Handshake                           | 0        |     | ns       |          |
| 20     | TdDAVOf(DAC) | - DAV I to DAC † Delay—Output<br>3-Wire Handshake                        | - 0      |     | ns       |          |
| 21     | ThDO(DAC)    | Data Output to DAC † Hold Time—<br>3-Wire Handshake                      | 2        |     | TcPC     |          |
| 22     | TdDACIr(DAV) | DAC † to DAV † Delay—Output<br>3-Wire Handshake                          | 2        |     | TcPC     |          |
| 23     | TdDAVOr(DAC) | DAV ↑ to DAC↓ Delay—Output<br>3-Wire Handshake                           | 0        |     | ns       |          |

NOTES:

1. This time can be extended through the use of the deskew timers.

\*Timings are preliminary and subject to change.



### Strobed Handshake



### Interlocked Handshake





### 3-Wire Handshake





### Counter/Timer Timing

| Number | Symbol    | Parameter                                                     | Min | Μαχ | Units | Notes* |
|--------|-----------|---------------------------------------------------------------|-----|-----|-------|--------|
| 1      | TcCI      | Counter Input Cycle Time                                      | 500 |     | ns    |        |
| 2      | TCIh      | Counter Input High Width                                      | ns  |     |       |        |
| 3      | TwCI1     | Counter Input Low Width                                       | 230 |     | ns    |        |
| 4      | TfCI      | Counter Input Fall Time                                       |     | 20  | ns    |        |
| 5      | TrCI      | Counter Input Rise Time                                       |     |     | ns    |        |
| 6      | TsTI(PC)  | Trigger Input to PCLK ↓ Setup Time<br>(Timer Mode)            |     |     | ns    | 1      |
| 7      | TsTI(CI)  | Trigger Input to Counter Input ↓ Setup Time<br>(Counter Mode) | ns  | 1   |       |        |
| 8—     | - TwTI    | -Trigger Input Pulse Width (High or Low)                      |     |     | ns    |        |
| 9      | TsGI(PC)  | Gate Input to PCLK ↓ Setup Time<br>(Timer Mode)               |     |     | ns    | 1      |
| 10     | TsGI(CI)  | Gate Input to Counter Input ↓ Setup Time<br>(Counter Mode)    |     |     | ns    | 1      |
| 11     | -ThGI(PC) | -Gate Input to PCLK ↓ Hold Time (Timer Mode).                 |     |     | ns    | l      |
| 12     | ThGI(CI)  | Gate Input to Counter Input ↓ Hold Time<br>(Counter Mode)     |     |     | ns    | 1      |
| 13     | TdPC(CO)  | PCLK to Counter Output Delay (Timer Mode)                     |     |     | ns    |        |
| 14     | TdCI(CO)  | Counter Input to Counter Output Delay<br>(Counter Mode)       |     |     | ns    |        |

NOTES:

1. These parameters must be met to guarantee trigger or gate are valid for the next counter/timer cycle.

\*Timings are preliminary and subject to change.

PCLK -(11)--(13) PCLK/2 (INTERNAL) -)→ | (6) (1) ••• 0 5---(10 COUNTER 0-(14) TRIGGER (1) GATE COUNTER OUTPUT

### **REQUEST WAIT Timing**

| Number | Symbol      | Parameter               | Min | Μαχ | Units        | Notes* |
|--------|-------------|-------------------------|-----|-----|--------------|--------|
| 1      | TdRD(REQ)   | RD ↓ to REQ ↓ Delay     |     |     | ns           |        |
| 2      | TdRD(WAIT)  | RD + to WAIT + Delay    |     |     | ns           |        |
| 3      | TdWR(REQ)   | ₩R ↓ to REQ ↓ Delay     |     |     | ns           |        |
| 4      | TdWR(WAIT)  | WR   to WAIT   Delay    |     |     | ns           |        |
| 5      | TdPC(REQ)   | PCLK ↓ to REQ ↑ Delay   |     |     | ns           |        |
| 6      | TdPC(WAIT)  | PCLK↓ to WAIT↑ Delay    |     |     | ns           |        |
| 7      | TdACK(REQ)  | ACKIN I to REQ † Delay  |     |     | TcPC<br>+ ns | 1      |
| 8      | TdACK(WAIT) | ACKIN ↓ to WAIT ↑ Delay |     |     | TcPC<br>+ ns | 1      |

NOTES:

 The delay is from DAV 4 for 3-Wire Input Handshake. The delay is from DAC 1 for 3-Wire Output Handshake.

\*Timings are preliminary and subject to change.





A BO AND AN INCOME AN ANY AND AND

### **Reset Timing**

| Number | Symbol   | Parameter                                                                             | Min | Max | Units | Notes* |
|--------|----------|---------------------------------------------------------------------------------------|-----|-----|-------|--------|
| 1      | TdRD(WR) | Delay from RD ↑ to WR ↓ for No Reset                                                  | 50  |     | ns    |        |
| 2      | TdWR(RD) | Delay from WR † to RD ↓ for No Reset                                                  | 50  |     | ns    |        |
| 3      | TwRES    | Minimum Width of $\overline{\text{RD}}$ and $\overline{\text{WR}}$ both Low for Reset | 250 |     | ns    |        |

\*Timings are preliminary and subject to change.



### **Miscellaneous** Port Timing

| Number | Symbol | Parameter                                              | Min   | Μαχ | Units | Notes* |
|--------|--------|--------------------------------------------------------|-------|-----|-------|--------|
| 1      | TrI    | Any Input Rise Time                                    |       | 100 | ns    |        |
| 2      | TfI    | Any Input Fall Time                                    |       | 100 | ns    |        |
| 3      | Twl's  | l's Catcher High Width                                 | 250   |     | ns    | 1      |
| 4      | TwPM   | Pattern Match Input Valid (Bit Port)                   | 750 - |     | ns    |        |
| 5      | TsPMD  | Data Latched on Pattern Match Setup Time<br>(Bit Port) | 0     |     | ns    |        |
| 6      | ThPMD  | Data Latched on Pattern Match Hold Time<br>(Bit Port)  | 1000  |     | ns    |        |

NOTES:

1. If the input is programmed inverting, a Low-going pulse of the same width will be detected.

\*Timings are preliminary and subject to change.



### **Ordering Information**

| Туре                        | Package                                                              | Temp                                         | Clock | Description                                   |
|-----------------------------|----------------------------------------------------------------------|----------------------------------------------|-------|-----------------------------------------------|
| Z8536 B1<br>B6<br>D1        | Plastic 40 pin<br>Plastic 40 pin<br>Ceramic 40 pin                   | 0/ + 70°C<br>-40/ + 85°C<br>0/ + 70°C        | 4MHz  | Z8536 Counter/Timer and<br>Parallel I/O Unit. |
| D2<br>D6                    | Ceramic 40 pin<br>Ceramic 40 pin                                     | -55/+125°C<br>-40/+85°C                      |       |                                               |
| Z8536A B1<br>B6<br>D1<br>D6 | Plastic 40 pin<br>Plastic 40 pin<br>Ceramic 40 pin<br>Ceramic 40 pin | 0/+70°C<br>-40/+85°C<br>0/+70°C<br>-40/+85°C | 6MHz  |                                               |

### Packages

Plastic

Ceramic

15.36

15.24

-



## FIFO Input/Output Interface Unit

**STS** 28538 FIO

### Features

- 128-byte FIFO buffer provides asynchronous bidirectional CPU/CPU or CPU/peripheral interface, expandable to any width in byte increments by use of multiple Z8060 FIO's
- Interlocked 2-Wire or 3-Wire Handshake logic port mode; Z-BUS or non-Z-BUS interface.
- Pattern-recognition logic stops DMA transfers and/or interrupts CPU; preset byte count can initiate variable-length DMA transfers.

### General Description

The Z8538 FIO provides an asynchronous 128-byte FIFO buffer between two CPUs or between a CPU and a peripheral device. This buffer interface expands to a 16-bit or wider data path and expands in depth to add as many Z8060 FIFOs (and an additional FIO) as are needed.

The FIO manages data transfers by assuming Z-BUS, non-Z-BUS microprocessor (a generalized microprocessor interface), Interlocked

- Seven sources of vectored/nonvectored interrupt which include pattern-match, byte count, empty or full buffer status; a dedicated "mailbox" register with interrupt capability provides CPU/CPU communication.
- REQUEST/WAIT lines control high-speed data transfers.
- All functions are software controlled via directly addressable read/write registers.

2-Wire Handshake, and 3-Wire Handshake operating modes. These modes interface dissimilar CPUs or CPUs and peripherals running under differing speeds or protocols, allowing asynchronous data transactions and improving I/O overhead by as much as two orders of magnitude. Figures 1 and 2 show how the signals controlling these operating modes are mapped to the FIO pins.



Figure 1. Logic Functions



Figure 2. Pin Configuration

78538 FIO

### General Description (Continued)

The FIO supports the Z-BUS interrupt protocols, generating seven sources of interrupts upon any of the following events: a write to a message register, change in data direction, pattern match, status match, over/underflow error, buffer full and buffer empty status. Each interrupt source can be enabled or disabled, and can also place an interrupt vector on the port address/data lines.

The data transfer logic of the FIO has been

specially designed to work with DMA (Direct Memory Access) devices for high-speed transfers. It provides for data transfers to or from memory each machine cycle, while the DMA device generates memory address and control signals. The FIO also supports the variably sized block length, improving system throughput when multiple variable length messages are transferred amongst several sources.



Figure 3. FIO Block Diagram

### Functional Description

**Operating Modes.** Ports 1 and 2 operate in any of twelve combinations of operating modes, listed in Table 2. Port 1 functions in either the Z-BUS or non-Z-BUS microprocessor modes, while Port 2 functions in Z-BUS, non-Z-BUS, Interlocked 2-Wire Handshake, and 3-Wire Handshake modes. Table 1 describes the signals and their corresponding pins in each of these modes. The pin diagrams of the FIO are identical, except for two pins on the Port 1 side, which select that port's operating mode. Port 2's operating mode is programmed by two bits in Port 1's Control register 0. Table 2 describes the combinations of operating modes; Table 3 describes the control signals mapped to pins A-J in the five possible operating modes.



| Control<br>Signal<br>Pins | Z-BUS<br>Low Byte | Z-BUS<br>High Byte | Non-Z-BUS        | Interlocked<br>HS Port* | 3-Wir●<br>HS Port* |
|---------------------------|-------------------|--------------------|------------------|-------------------------|--------------------|
| A                         | REQ/WT            | REQ/WT             | REQ/WT           | RFD/DAV                 | RFD/DAV            |
| В                         | DMASTB            | DMASTB             | DACK             | ACKIN                   | DAV/DAC            |
| С                         | DS                | DS                 | RD               | FULL                    | DAC/RFD            |
| D                         | $R/\overline{W}$  | R/W                | WR               | EMPTY                   | EMPTY              |
| E                         | CS                | CS                 | CE               | CLEAR                   | CLEAR              |
| F                         | AS                | ĀS                 | $C/\overline{D}$ | DATA DIR                | DATA DIR           |
| G                         | INTACK            | A <sub>0</sub>     | INTACK           | INO                     | INO                |
| H                         | IEO               | Al                 | IEO              | OUT1                    | OUT1               |
| Ι                         | IEI               | A <sub>2</sub>     | IEI              | ŌĒ                      | OE                 |
| 1                         | ĪNT               | A <sub>3</sub>     | INT              | OUT3                    | OUT3               |
| *2 aida                   | anlu              |                    |                  |                         |                    |

\*2 side only.

| Table 1. Pin Assignment | ignments | Assig | Pin | 1. | able |
|-------------------------|----------|-------|-----|----|------|
|-------------------------|----------|-------|-----|----|------|

| Mode | $\mathbf{M}_{1}$ | M <sub>0</sub> | Bl | BO | Port 1          | Port 2           |
|------|------------------|----------------|----|----|-----------------|------------------|
| 0    | 0                | 0              | 0  | 0  | Z-BUS Low Byte  | Z-BUS Low Byte   |
| 1    | 0                | 0              | 0  | 1  | Z-BUS Low Byte  | Non-Z-BUS        |
| 2    | 0                | 0              | 1  | 0  | Z-BUS Low Byte  | 3-Wire Handshake |
| 3    | 0                | 0              | 1  | 1  | Z-BUS Low Byte  | 2-Wire Handshake |
| 4    | 0                | 1              | 0  | 0  | Z-BUS High Byte | Z-BUS High Byte  |
| 5    | 0                | 1              | 0  | 1  | Z-BUS High Byte | Non-Z-BUS        |
| 6    | 0                | 1              | 1  | 0  | Z-BUS High Byte | 3-Wire Handshake |
| 7    | 0                | 1              | 1  | 1  | Z-BUS High Byte | 2-Wire Handshake |
| 8    | 1                | 0              | 0  | 0  | Non-Z-BUS       | Z-BUS Low Byte   |
| 9    | 1                | 0              | 0  | 1  | Non-Z-BUS       | Non-Z-BUS        |
| 10   | 1                | 0              | 1  | 0  | Non-Z-BUS       | 3-Wire Handshake |
| 11   | 1                | 0              | 1  | 1  | Non-Z-BUS       | 2-Wire Handshake |

| Table | 2. | Operating | Modes |
|-------|----|-----------|-------|
|-------|----|-----------|-------|



# Functional Description (Continued)









# Pins Common To Both Sides

| Pin Pin Pin<br>Signals Names Numbe |        | Pin<br>Numbers | Signal<br>Description                            |  |  |  |
|------------------------------------|--------|----------------|--------------------------------------------------|--|--|--|
| M <sub>0</sub>                     | MO     | 21             | M <sub>1</sub> and M <sub>0</sub> program Port 1 |  |  |  |
| Ml                                 | Ml     | 19             | side CPU interface                               |  |  |  |
| +5 Vdc                             | +5 Vdc | 40             | DC power source                                  |  |  |  |
| GND                                | GND    | 20             | DC power ground                                  |  |  |  |

# Z-BUS Low Byte Mode

| Pin<br>Signals                                     | Pin<br>Names                   | Pin Nu<br>Po<br>1 |       | Signal<br>Description                                                                                                                                |
|----------------------------------------------------|--------------------------------|-------------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| AD <sub>0</sub> -AD <sub>7</sub><br>(Address/Data) | D <sub>0</sub> -D <sub>7</sub> | 11-18             | 29-22 | Multiplexed bidirectional address/data lines, Z-BUS compatible.                                                                                      |
| REQ/WAIT<br>(Request/Wait)                         | A                              | 1                 | 39    | Output, <u>active</u> Low, REQUEST (ready) line for DMA<br>transfer; WAIT line (open-drain) output for syn-<br>chronized CPU and FIO data transfers. |
| DMASTB<br>(Direct Memory<br>Access Strobe)         | В                              | 2                 | 38    | Input, active Low. Strobes DMA data to and from the FIFO buffer.                                                                                     |
| DS<br>(Data Strobe)                                | С                              | 3                 | 37    | Input, active Low. Provides timing for data trans-<br>fer to or from FIO.                                                                            |
| R/W<br>(Read/Write)                                | D                              | 4                 | 36    | Input; active High signals CPU read from FIO;<br>active Low signals CPU write to FIO.                                                                |
| CS<br>(Chip Select)                                | Ε                              | 5                 | 35    | Input, active L <u>ow.</u> Enables FIO. Latched on the rising edge of AS.                                                                            |
| ĀS<br>(Address Strobe)                             | F                              | 6                 | 34    | Input, active Low. Addresses, $\overline{\text{CS}}$ and $\overline{\text{INTACK}}$ sampled while $\overline{\text{AS}}$ Low.                        |
| INTACK<br>(Interrupt<br>Acknowledge)               | G                              | 7                 | 33    | Input, active Low. Acknowledges an interrupt.<br>Latched on the rising edge of AS.                                                                   |
| IEO<br>(Interrupt<br>Enable Out)                   | н                              | 8                 | 32    | Output, active High. Sends interrupt enable to lower priority device IEI pin.                                                                        |
| IEI<br>(Interrupt<br>Enable In)                    | I                              | 9                 | 31    | Input, active High. Receives interrupt enable from higher priority device IEO signal.                                                                |
| INT<br>(Interrupt)                                 | 1                              | 10                | 30    | Output, open drain, active Low. Signals FIO inter-<br>rupt request to CPU.                                                                           |

Table 3. Signal/Pin Descriptions

# Z-BUS High Byte Mode (Continued)

| Pin<br>Signals                                     |                                |       | mbers<br>ort<br>2 | Signal<br>Description                                                                                                                                |
|----------------------------------------------------|--------------------------------|-------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| AD <sub>0</sub> -AD <sub>7</sub><br>(Address/Data) | D <sub>0</sub> -D <sub>7</sub> | 11-18 | 29-22             | Multiplexed bidirectional address/data lines, Z-BUS compatible.                                                                                      |
| REQ/WAIT<br>(Request/Wait)                         | A                              | 1     | 39                | Output, <u>active</u> Low, REQUEST (ready) line for DMA<br>transfer; WAIT line (open-drain) output for syn-<br>chronized CPU and FIO data transfers. |
| DMASTB<br>(Direct Memory<br>Access Strobe)         | В                              | 2     | 38                | Input, active Low. Strobes DMA data to and from the FIFO buffer.                                                                                     |
| DS<br>(Data Strobe)                                | С                              | 3     | 37                | Input, active Low. Provides timing for transfer of data to or from FIO.                                                                              |
| R/W<br>(Read/Write)                                | D                              | 4     | 36                | Input, active High. Signals CPU read from FIO; active<br>Low signals CPU write to FIO.                                                               |
| CS<br>(Chip Select)                                | Е                              | 5     | 35                | Input, active Low. Enables FIO. Latched on the rising edge of $\overline{\mathrm{AS}}$ .                                                             |
| AS<br>(Address Strobe)                             | F                              | 6     | 34                | Input, active Low. Addresses, $\overline{CS}$ and $\overline{INTACK}$ are sampled while $\overline{AS}$ is Low.                                      |
| A <sub>0</sub><br>(Address Bit 0)                  | G                              | 7     | 33                | Input, active High. With $A_1$ , $A_2$ , and $A_3$ , addresses FIO internal registers.                                                               |
| A <sub>1</sub><br>(Address Bit 1)                  | Н                              | 8     | 32                | Input, active High. With $A_0$ , $A_2$ , and $A_3$ , addresses FIO internal registers.                                                               |
| Å <sub>2</sub><br>(Address Bit 2)                  | Ι                              | 9     | 31                | Input, active High. With $\dot{A_0}$ , $A_1$ , and $A_3$ , addresses FIO internal registers.                                                         |
| A <sub>3</sub><br>(Address Bit 3)                  | 1                              | 10    | 30                | Input, active High. With $A_0, \ A_1, \ \text{and} \ A_2, \ \text{addresses}$ FIO internal registers.                                                |

Table 3. Signal/Pin Descriptions (Continued)



# Non-Z-BUS Mode

| Pin<br>Signals                           | Pin<br>Names                   | Pin Nu<br>Po<br>1 |       | Signal<br>Description                                                                                                                     |
|------------------------------------------|--------------------------------|-------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------|
| D <sub>0</sub> -D <sub>7</sub><br>(Data) | D <sub>0</sub> -D <sub>7</sub> | 11-18             | 29-22 | Bidirectional data bus.                                                                                                                   |
| REQ/WT<br>(Request/Wait)                 | A                              | 1                 | 39    | Output, active Low, REQUEST (ready) line for DMA transfer; WAIT line (open-drain) output for syn-<br>chronized CPU and FIO data transfer. |
| DACK<br>(DMA Acknowledge)                | В                              | 2                 | 38    | Input, active Low. DMA acknowledge.                                                                                                       |
| RD<br>(Read)                             | С                              | 3                 | 37    | Input, active Low. Signals CPU read from FIO.                                                                                             |
| WR<br>(Write)                            | D                              | 4                 | 36    | Input, active Low. Signals CPU write to FIO.                                                                                              |
| CE<br>(Chip Select)                      | E                              | 5                 | 35    | Input, active Low. Used to select FIO.                                                                                                    |
| C/D<br>(Control/Data)                    | F                              | 6                 | 34    | Input, active High. Identifies control byte on $D_0-D_7$ ;<br>active Low identifies data byte on $D_0-D_7$ .                              |
| INTACK<br>(Interrupt<br>Acknowledge)     | G                              | 7                 | 33    | Input, active Low. Acknowledges an interrupt.                                                                                             |
| IEO<br>(Interrupt<br>Enable Out)         | н                              | 8                 | 32    | Output, active High. Sends interrupt enable to lower priority device IEI pin.                                                             |
| IEI<br>(Interrupt<br>Enable In)          | Ι                              | 9                 | 31    | Input, active High. Receives interrupt enable from higher priority device IEO signal.                                                     |
| INT<br>(Interrupt)                       | l                              | 10                | 30    | Output, open drain, active Low. Signals FIO interrupt to CPU.                                                                             |

Table 3. Signal/Pin Descriptions (Continued)

#### Port 2-I/O Port Mode

| Pin<br>Signals                                | Pin<br>Names                   | Pin<br>Numbers | Mode                    | Signal<br>Description                                                                                                                                                                                      |
|-----------------------------------------------|--------------------------------|----------------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D <sub>0</sub> -D <sub>7</sub><br>(Data)      | D <sub>0</sub> -D <sub>7</sub> | 29-22          | 2-Wire HS*<br>3-Wire HS | Bidirectional data bus.                                                                                                                                                                                    |
| RFD/DAV<br>(Ready for Data/Data<br>Available) | A                              | 39             | 2-Wire HS<br>3-Wire HS  | Output, RFD active High. Signals peripherals that FIC is ready to receive data. DAV active Low signals that FIO is ready to send data to peripherals.                                                      |
| ACKIN<br>(Acknowledge Input)                  | В                              | 38             | 2-Wire HS               | Input, active Low. Signals FIO that output data is received by peripherals or that input data is valid.                                                                                                    |
| DAV/DAC<br>(Data Available/Data<br>Accepted)  | В                              | 38             | 3-Wire HS               | Input; DAV (active Low) signals that data is valid on<br>bus. DAC (active High) signals that output data is<br>accepted by peripherals.                                                                    |
| FULL                                          | С                              | 37             | 2-Wire HS               | Output, open drain, active High. Signals that FIO buffer is full.                                                                                                                                          |
| DAC/RFD<br>(Data Accepted/Ready<br>for Data)  | C                              | 37             | 3-Wire HS               | Direction controlled by internal programming. Both<br>active High. DAC (an output) signals that FIO has<br>received data from peripheral; RFD (an input) signals<br>that the listeners are ready for data. |
| EMPTY                                         | D                              | 36             | 2-Wire HS<br>3-Wire HS  | Output, open drain, active High. Signals that FIFO buffer is empty.                                                                                                                                        |
| CLEAR                                         | E                              | 35             | 2-Wire HS<br>3-Wire HS  | Programmable input or output, active Low. Clears all data from FIFO buffer.                                                                                                                                |
| DATA DIR<br>(Data Direction)                  | F                              | 34             | 2-Wire HS<br>5-Wire HS  | Programmable input or output. Active High signals<br>data input to Port 2; Low signals data output from<br>Port 2.                                                                                         |
| IN <sub>0</sub>                               | G                              | 33             | 2-Wire HS<br>3-Wire HS  | Input line to $D_0$ of Control Register 3.                                                                                                                                                                 |
| OUT <sub>1</sub>                              | Н                              | 32             | 2-Wire HS<br>3-Wire HS  | Output line from $D_1$ of Control Register 3.                                                                                                                                                              |
| OE<br>(Output Enable)                         | Ι                              | 31             | 2-Wire HS<br>3-Wire HS  | Input, active Low. When Low, enables bus drivers.<br>When High, floats bus drivers at high impedance.                                                                                                      |
| OUT <sub>3</sub>                              | 1                              | 30             | 2-Wire HS<br>3-Wire HS  | Output line from $D_3$ of Control register 3.                                                                                                                                                              |

\*Handshake

Table 3. Signal/Pin Descriptions (Continued)

### Reset

The FIO can be reset under either hardware or software control by one of the following methods:

- By forcing both AS and DS Low simultaneously in Z-BUS mode (normally illegal).
- By forcing RD and WR Low simultaneously in non-Z-BUS mode.
- By writing a 1 to the Reset bit in Control register 0 for software reset.

In the Reset state, all control bits are cleared to 0. Only after clearing the Reset bit (by

writing a 0 to it) can the other command bits be programmed. This action is true for both sides of the FIO when programmed as a CPU interface.

For proper system control, when Port 1 is reset, Port 2 is also reset. In addition, all Port 2's outputs are floating and all inputs are ignored. To initiate the data transfer, Port 2 must be enabled by Port 1. The Port 2 CPU can determine when it is enabled by reading Control register 0, which reads "floating" data bus if not enabled and " $01_{\text{H}}$ " if enabled.



#### **CPU** Interfaces

The FIO is designed to work with both Z-BUS- and non-Z-BUS-type CPUs on both Port 1 and Port 2. The Z-BUS configuration interfaces CPUs with time-multiplexed address and data information on the same pins. The Z8001, Z8002, and Z8 are examples of this type of CPU. The  $\overline{AS}$  (Address Strobe) pin is used to latch the address and chip select information sent out by the CPU. The  $R/\overline{W}$  (Read/Write) pin and the  $\overline{DS}$  (Data Strobe) pin are used for timing reads and writes from the CPU to the FIO (Figures 6 and 7).

The non-Z-BUS configuration is used for CPUs where the address and data buses are separate. Examples of this type of <u>CPU</u> are the Z80 and 8080. The <u>RD</u> (Read) and <u>WR</u> (Write) pins are used to time reads and writes from the CPU to the FIO (Figures 9 and 10). The  $C/\overline{D}$ (Control/Data) pin is used to directly access the FIFO buffer ( $C/\overline{D}=0$ ) and to access the other registers ( $C/\overline{D}=1$ ). Read and write to all



Figure 6. Z-BUS Read Cycle Timing



Figure 7. Z-BUS Write Cycle Timing



#### **CPU Interfaces** (Continued)

registers except the FIFO buffer<sup>1</sup> are two-step operations, described as follows (Figure 8). First, write the address  $(C/\overline{D} = 1)$  of the register to be accessed into the Pointer Register (State 0); second, read or write  $(C/\overline{D} = 1)$  to the register pointed at previously (State 1). Continuous status monitoring can be performed in State 1 by continuous Control Read operations  $(C/\overline{D} = 1)$ .



<sup>1</sup>The FIFO buffer can also be accessed by this two-step operation.

Figure 8. Register Access in Non-Z-BUS Mode



Figure 9. Non-Z-BUS Read Cycle Timing



Figure 10. Non-Z-BUS Write Cycle Timing

# WAIT Operation

<u>When data is output by the CPU, the</u>  $\overline{\text{REQ}}/\overline{\text{WT}}$  (WAIT) pin is active (Low) only when the FIFO buffer is full, the chip is selected, and the FIFO buffer is addressed. WAIT goes inactive when the FIFO buffer is not full. <u>When</u> data is input by the CPU, the <u>REQ/WT</u> pin becomes active (Low) only when the FIFO buffer is empty, the chip is selected, and the FIFO buffer is addressed. WAIT goes inactive when the FIFO buffer is not empty.



### Interrupt Operation

The FIO supports the prioritized daisy chain interrupt protocol for both Z-BUS and non-Z-BUS operating modes (for more details refer to the Z-BUS Summary).

Each side of the FIO has seven sources of interrupt. The priorities of these devices are fixed in the following order (highest to lowest): Mailbox Message, Change in Data Direction, Pattern Match, Status Match, Overflow/ Underflow Error, Buffer Full, and Buffer Empty. Each interrupt source has three bits that control how it generates the interrupt. These bits are Interrupt Pending (IP), Interrupt Enable (IE), and Interrupt Under Service (IUS).

In addition, each side of the FIO has an interrupt vector and four bits controlling the FIO interrupt logic. These bits are Vector Includes Status (VIS), Master Interrupt Enable (MIE), Disable Lower Chain (DLC), and No Vector (NV).

A typical Interrupt Acknowledge cycle for Z-BUS operation is shown in Figure 11 and for non-Z-BUS operation in Figure 12. The only difference is that in Z-BUS mode, INTACK is latched by  $\overline{\text{AS}}$ , and in non-Z-BUS mode INTACK is not latched.

When MIE = 1, reading the vector always includes status, independent of the state of the VIS bit. In this way, when VIS = 0, all information can be obtained with one additional read, thus conserving vector space. When MIE = 0, reading the vector register returns the unmodified base vector so that it can be verified.

In non-Z-BUS mode, IPs do not get set while in State 1. Therefore, in order to minimize interrupt latency, the FIO should be left in State 0.



Figure 11. Z-BUS Interrupt Acknowledge Cycle



Interrupt Operation (Continued)



Figure 12. Non-Z-BUS Interrupt Acknowledge Cycle

### **CPU** to **CPU** Operation

**DMA Operation.** The FIO is particularly well suited to work with a DMA in both Z-BUS and non-Z-BUS modes. A data transfer between the FIO and system memory can take place during every machine cycle on both sides of the FIO simultaneously.

In Z-BUS mode, the  $\overline{\text{DMASTB}}$  pin (DMA Strobe) is used to read or write into the FIFO buffer. The  $\overline{R/W}$  (Read/Write) and  $\overline{DS}$  (Data Strobe) signals are ignored by the FIO;

however, the  $\overline{CS}$  (Chip Select) signal is not ignored and therefore must be kept invalid. Figures 13 and 14 show typical timing.

In Non-Z-BUS mode, the DACK pin (DMA Acknowledge) is used to tell the FIO that its DMA request is granted. After DACK goes Low, every read or write to the FIO goes into the FIFO buffer. Figures 15 and 16 show typical timing.



Figure 13. Z-BUS FIO to Memory Data Transaction



# CPU to CPU Operation (Continued)



Figure 14. Z-BUS Memory to FIO Data Transaction



Figure 15. Non-Z-BUS FIO to Memory Transaction







#### CPU to CPU Operation (Continued)

The FIO provides a special mode to enhance its DMA transfer capability. When data is written into the FIFO buffer, the REO/WT (REOUEST) pin is active (Low) until the FIFO buffer is full. It then goes inactive and stays inactive until the number of bytes in the FIFO buffer is equal to the value programmed into the Byte Count Comparison register. Then the **REQUEST** signal goes active and the sequence starts over again (Figure 17).



- NOTES:
- 1. FIFO empty.
- 2. REQUEST enabled, FIO requests DMA transfer.
- 3. DMA transfers data into the FIO.
- 4. FIFO full, REQUEST inactive.
- 5. The FIFO empties from the opposite port until the number of bytes in the FIFO buffer is the same as the number programmed in the Byte Count Comparison register.

Figure 17. Byte Count Control: Write to FIO

Message Registers. Two CPUs can communicate through a dedicated "mailbox" register without involving the 128  $\times$  8 bit FIFO buffer (Figure 19). This mailbox approach is useful

When data is read from the FIO, the REO/WT pin (REOUEST) is inactive until the number of bytes in the FIFO buffer is equal to the value programmed in the Byte Count Comparison register. The REQUEST signal then goes active and stays active until the FIFO buffer is empty. When empty, REQUEST goes inactive and the sequence starts over again (Figure 18).



NUMBER IN BYTE COUNT COMPARISON REGISTER

NOTES:

- 1. FIFO empty
- 2. CPU/DMA fills FIFO buffer from the opposite port.
- 3. Number of bytes in FIFO buffer is the same as the number
- of bytes programmed in the Byte Count Comparison register. **REQUEST** goes active.
- 5. DMA transfers data out of FIFO until it is empty.

Figure 18. Byte Count Control: Read from FIO

for transferring control parameters between the interfacing devices on either side of the FIO without using the FIFO buffer. For example, when Port 1's CPU writes to the



NOTE: Usable only for CPU/CPU interface. Figure 19. Message Register Operation

#### CPU to CPU Operation (Continued)

Message Out register, Port 2's message IP is set. If interrupts are enabled, Port 2's CPU is interrupted. Port 2's message IP status is readable from the Port 1 side. When Port 2's CPU reads the data from its Message In register, the Port 2 IP is cleared. Thus, Port 1's CPU can read when the message has been read and can now send another message or follow whatever protocol that is set up between the two CPU's. The same transfer can also be made from Port 2's CPU to Port 1's CPU.

**CLEAR (Empty) FIFO Operation.** The CLEAR FIFO bit (active Low) clears the FIFO buffer of data. Writing a 0 to this bit empties the FIFO buffer, inactivates the REQUEST line, and disables the handshake (if programmed). The CLEAR bit does not affect any control or data register. To remove the CLEAR state, write a 1 to the CLEAR bit.

In CPU/CPU mode, under program control, only one of the ports can empty the FIFO by writing to its Control Register 3, bit 6. The Port 1 CPU must program bit 7 in Control Register 3 to determine which port controls the CLEAR FIFO operation (0 = Port 1 control; 1 = Port 2 control).

78538 FIO

**Direction of Data Transfer Operation.** The Data Direction bit controls the direction of data transfer in the FIFO buffer. The Data Direction bit is defined as 0 = output from CPU and 1 = input to CPU. This bit reads correctly when read by either port's CPU. For example, if Port 1's CPU reads a 0 (CPU output) in its Data Direction bit, then Port 2's CPU reads a 1 (input to CPU) in its Data Direction bit.

In CPU/CPU mode, under program control, only one of the ports can control the direction of data transfer. The Port 1 CPU must program bit 5 in Control Register 3 to determine which port controls the data direction (0 = Port 1control; 1 = Port 2 control). Figure 20 shows FIO data transfer options.



Figure 20. FIO Data Transfer Options



# CPU to I/O Operation

When Port 2 is programmed in the Interlocked 2-Wire Handshake mode or the 3-Wire Handshake mode, and Port A is programmed in Z-BUS or non-Z-BUS Microprocessor mode, the FIO interfaces a CPU and a peripheral device. In the Interlocked 2-Wire Handshake mode, RFD/DAV and ACKIN strobe data to and from Port 2. In the 3-Wire Handshake mode, RFD/DAV, DAV/DAC, and DAC/RFD signals control data flow.

Interlocked 2-Wire Handshake. In the Interlocked Handshake, the action of the FIO must be acknowledged by the other half of the handshake before the next action can take place. In output mode, Port 2 does not indicate that new data is available until the external device indicates it is ready for the data. Similarly, in input mode, Port 2 does not indicate that it is ready for new data until the data source indicates that the previous byte of the data is no longer available, thereby acknowledging Port 2's acceptance of the last byte. This allows the FIO to directly interface to a Z8's port, a CIO's port, a UPC's port, another FIO port, or another FIFO Z8060, with no external logic (Figures 21 and 22).

**3-Wire Handshake.** The 3-Wire Handshake is designed for applications in which one output port is communicating with many input ports simultaneously. It is essentially the same as the Interlocked Handshake, except that two signals are used to indicate that an input port is ready for new data or that it has accepted the present data. In the 3-Wire Handshake, the rising edge of the RFD status line indicates that the port is ready for data, and the rising edge of the DAC status line indicates that the data has been accepted. With 3-Wire Handshake, the lines of many input ports can be bussed together with open-drain drivers and the out-

put port knows when all of the ports are ready and have accepted the data. This handshake is the same handshake used in the IEEE-488 Instruments. Since the port's direction can be changed under software control, bidirectional IEEE-488-type transfers can be performed. Figures 23 and 24 show the timings associated with 3-Wire Handshake communications.

**CLEAR FIFO Operation.** In CPU-to-I/O operation, the CLEAR FIFO operation can be performed by the CPU side (Port 1) under software control as previously explained. The CLEAR FIFO operation can also be performed under hardware control by defining the CLEAR pin of Port 2 as an input (Control Register 3, bit 7 = 1).

For cascading purposes, the CLEAR pin can also be defined as an output (Control Register 3, bit 7 = 0), which reflects the current state of the CLEAR FIFO bit. It can then empty other FIOs or initialize other devices in the system.

**Data Direction Control.** In CPU-to-I/O mode, the direction of data transfer can be controlled by the CPU side (Port 1) under software control as previously explained. The data direction can also be determined by hardware control by defining the Data Direction pin of Port 2 as an input (Control Register 3, bit 5 = 1).

For cascading purposes, the Data Direction pin can also be defined as an output (Control Register 3, bit 5 = 0) pin which reflects the current state of the Data Direction bit. It can then be used to control the direction of data transfer for other FIOs or for external logic.

On the Port 2 side, when data direction is 0, Port 2 is in Output Handshake mode. When data direction is 1, Port 2 is in Input Handshake mode.



# CPU to I/O Operation (Continued)



Figure 21. Interlocked Handshake Timing (Imput) Port 2 Side Only



Figure 22. Interlocked Handshake Timing (Output) Port 2 Side Only



Figure 23. Input (Acceptor) Timing IEEE-488 Port: Port 2 Side Only



Figure 24. Output (Source) Timing IEEE-488 HS Port: Port 2 Side Only



### Programming

The programming of the FIO is greatly simplified by the efficient grouping of the various operation modes in the control registers. Since all of the control registers are read/write, the need for maintaining their image in system memory is eliminated. Also, the read/write feature of the registers aids in system debugging.

Each side of the FIO has 16 registers. All 16 registers are used by the Port 1 side; Control register 2 is not used on the Port 2 side. All registers are addressable 0<sub>H</sub> through F<sub>H</sub>.

In the Z-BUS Low Byte mode, the FIO allows two methods for register addressing under control of the Right Justify Address (RJA) bit in Control register 0. When RJA = 0, address bus bits 1-4 are used for register addressing and bits 5, 6, and 7 are ignored (Table 4). When RJA = 1, bits 0-3 are used for the register addresses, and bits 4-7 are ignored.

**Control Registers.** These four registers specify FIO operation. The Port 2 side control registers operate only if the Port 2 device is a CPU. The Port 2 CPU can control interface operations, including data direction, only when enabled by the setting of bit 0 in the Port 1 side of Control Register 2. A 1 in bit 1 of the same register enables the handshake logic.

**Interrupt Status Registers.** These four registers control and monitor the priority interrupt functions for the FIO.

**Interrupt Vector Register.** This register stores the interrupt service routine address. This vector is placed on  $D_0$ - $D_7$  when IUS is set by the Interrupt Acknowledge signal from the CPU. When bit 4 (Vector Includes Status) is set in Control Register 0, the reason for the interrupt

| Non Z-BUS                                           | D7-D4                                                                | D <sub>3</sub>                     | D <sub>2</sub>                     | D1                                 | D <sub>0</sub>                     |                 |
|-----------------------------------------------------|----------------------------------------------------------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|-----------------|
| Z-BUS High                                          |                                                                      | A3                                 | A <sub>2</sub>                     | A1                                 | A <sub>0</sub>                     |                 |
| Z-BUS Low $\begin{cases} RJA=0\\ RJA=1 \end{cases}$ | AD <sub>7</sub> -AD <sub>5</sub><br>AD <sub>7</sub> -AD <sub>4</sub> | AD <sub>4</sub><br>AD <sub>3</sub> | AD <sub>3</sub><br>AD <sub>2</sub> | AD <sub>2</sub><br>AD <sub>1</sub> | AD <sub>1</sub><br>AD <sub>0</sub> | AD <sub>0</sub> |
| Description                                         |                                                                      |                                    |                                    |                                    |                                    |                 |
| Control Register 0                                  | x                                                                    | 0                                  | 0                                  | 0                                  | 0                                  | x               |
| Control Register 1                                  | x                                                                    | 0                                  | 0                                  | 0                                  | 1                                  | x               |
| Interrupt Status Register 0                         | x                                                                    | 0                                  | 0                                  | 1                                  | 0                                  | x               |
| Interrupt Status Register 1                         | x                                                                    | 0                                  | 0                                  | 1                                  | 1                                  | x               |
| Interrupt Status Register 2                         | x                                                                    | 0                                  | 1                                  | 0                                  | 0                                  | x               |
| Interrupt Status Register 3                         | x                                                                    | 0                                  | 1                                  | 0                                  | 1                                  | x               |
| Interrupt Vector Register                           | x                                                                    | 0                                  | 1                                  | 1 '                                | 0                                  | x               |
| Byte Count Register                                 | x                                                                    | 0                                  | 1                                  | 1                                  | 1                                  | x               |
| Byte Count Comparison<br>Register                   | x                                                                    | 1                                  | 0                                  | 0                                  | 0                                  | x               |
| Control Register 2*                                 | x                                                                    | 1                                  | 0                                  | 0                                  | 1                                  | x               |
| Control Register 3                                  | x                                                                    | 1                                  | 0                                  | 1                                  | 0                                  | x               |
| Message Out Register                                | x                                                                    | 1                                  | 0                                  | 1                                  | 1                                  | x               |
| Message In Register                                 | x                                                                    | 1                                  | 1                                  | 0                                  | 0                                  | x               |
| Pattern Match Register                              | x                                                                    | 1                                  | 1                                  | 0                                  | 1                                  | x               |
| Pattern Mask Register                               | x                                                                    | 1                                  | 1                                  | 1                                  | 0                                  | x               |
| Data Buffer Register                                | x                                                                    | 1                                  | 1                                  | 1                                  | 1                                  | x               |

x = Don't Care

\*Register is only on Port 1 side



#### Programming Continued)

is encoded within the vector address in bits 1, 2, and 3. If bit 5 is set in Control register 0, no vector is output by the FIO during an Interrupt Acknowledge cycle. However, IUS is set as usual.

**Byte Count Compare Register.** This register contains a value compared with the byte count in the Byte Count register. If the Byte Count Compare interrupt is enabled, an interrupt will occur upon compare.

**Message Out Register.** Either CPU can place a message in its Message Out register. If the opposite side Message register interrupt is enabled, the receiving side CPU will receive an interrupt request, advising that a message is present in its Message In register. Bit 5 in Control Register 1 on the initiating side is set when a message is written. It is cleared when the message is read by the receiving CPU.

**Message In Register.** This register receives a message placed in the Message Out register by the opposite side CPU.

**Pattern Match Register.** This register contains a bit pattern matched against the byte in the Data Buffer register. When these patterns match, a Pattern Match interrupt will be generated, if previously enabled.

**Pattern Mask Register.** The Pattern Mask register may be programmed with a bit pattern mask that limits comparable bits in the Pattern Match register to non-masked bits (1 = mask).

**Data Buffer Register.** This register contains the data to be read from or written to the FIFO buffer.

**Byte Count Register.** This is a read-only register, containing the byte count for the FIFO buffer. The byte count is derived by subtracting the number of bytes read from the buffer from the number of bytes written into the buffer. The count is "frozen" for an accurate reading by setting bit 6 (Freeze Status register) in Control Register 1. This bit is cleared when the Byte Count register read is completed.



Figure 25. Typical Application: Node Controller



### Registers











**Registers** (Continued)







#### Registers (Continued)

A

#### Byte Count Register Address: 0111

| [    | D7 | D <sub>6</sub> | D <sub>5</sub> | D4 | D3   | D <sub>2</sub> | D,    | Do     |    |
|------|----|----------------|----------------|----|------|----------------|-------|--------|----|
| _    | 1  | 1              | 1              | 1  | I    | 1              | 1     |        |    |
| EFLE | СТ | S N            | UMB            | ER | OF I | BYTE           | IS II | N BUFF | ER |

Figure 28. Byte Count Register



Figure 29. Interrupt Vector Register

#### Pattern Mask Register

Address: 1110 (Read/Write)

| D7          | D <sub>6</sub> | D <sub>5</sub> | D4 | $D_3$ | D2 | D, | D <sub>0</sub> |
|-------------|----------------|----------------|----|-------|----|----|----------------|
| I           | I              | I              | L  | 1     | Ţ  | ł  | 1              |
|             |                | BITS           |    |       |    |    |                |
| IN P.<br>MA |                | ERN<br>1 OC    |    |       |    |    |                |
|             |                | ASP            |    |       |    |    |                |

Figure 31. Pattern Mask Register

#### Byte Count Comparison Register

Address: 1000 (Read/Write)

 D7
 D4
 D5
 D4
 D5
 D6
 D6

 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1<

Figure 33. Byte Count Comparison Register

Message In Register Address: 1100 (Read Only)



STORES MESSAGE RECEIVED FROM MESSAGE OUT REGISTER ON OPPOSITE PORT OF CPU

Figure 35. Message In Register

### **Pattern Match Register**

Address: 1011 (Read/Write)

| D,  | D <sub>6</sub> | D5 | D4 | $D_3$ | D2 | D, | Do   |
|-----|----------------|----|----|-------|----|----|------|
| 1   | T              | 1  | 1  | 1     | L  | 1  | L    |
| STO |                |    |    |       |    |    | VITH |

Figure 30. Pattern Match Register

### Data Buffer Register

Address: 1111 (Read/Write)



Figure 32. Data Buffer Register

#### Message Out Register Address: 1011 (Read/Write)

| - [ | D7 | D <sub>6</sub> | Dş | D4 | D3 | D2 | D1 | Do                 |
|-----|----|----------------|----|----|----|----|----|--------------------|
|     | 1  | 1              | 1  | L  | I  | L  | 1  | L                  |
|     |    |                |    |    |    |    |    | ESSAGE<br>T OF FIO |

Figure 34. Message Out Register



#### **Absolute Maximum Ratings**

| Voltages on all inputs and outputs   |
|--------------------------------------|
| with respect to GND0.3 V to $+7.0$ V |
| Operating Ambient                    |
| Temperature0°C to +70°C              |
| Storage Temperature65 °C to +150 °C  |

Stresses greater than those listed under Absolute Maximum Ratings may cause permanent damage to the device. This is a stress rating only; operation of the device at any condition above those indicated in the operational sections of these specifications is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

■ +4.75 V ≤  $V_{CC}$  ≤ +5.25 V

FROM OUTPUT

T<sub>A</sub> as specified in Ordering Information

Figure 37. Open-Drain Test Load

 $\blacksquare$  GND = 0 V

### **Standard Test Conditions**

The characteristics below apply for the following standard test conditions, unless otherwise noted. All voltages are referenced to GND. Positive current flows into the referenced pin. Standard conditions are as follows:



Figure 36. Standard Test Load

#### **DC Characteristics**

Symbol Parameter Min Μαχ Unit Condition VIH Input High Voltage 2.0  $V_{CC} + 0.3$ v VII Input Low Voltage -0.3 0.8 V 2.4 v  $I_{OH} = -250 \ \mu A$ V<sub>OH</sub> Output High Voltage V  $I_{OI} = +2.0 \text{ mÅ}$ Output Low Voltage VOL 0.4  $I_{OI} = +3.2 \text{ mA}$ 0.5 V  $0.4 \leq V_{IN} \leq +2.4V$ I<sub>II</sub> Input Leakage ±10.0 μA  $0.4 \leq V_{OUT} \leq +2.4V$ Output Leakage ±10.0 I<sub>OL</sub> μA V<sub>CC</sub> Supply Current 250 mĀ I<sub>CC</sub>

 $V_{CC}$  = 5 V ± 5% unless otherwise specified, over specified temperature range.



### Capacitance

| Symbol          | Parameter                 | Min | Max | Unit | <b>Test Condition</b> |
|-----------------|---------------------------|-----|-----|------|-----------------------|
| C <sub>IN</sub> | Input Capacitance         |     | 10  | pF   |                       |
| COUT            | Output Capacitance        |     | 15  | pF   | Unmeasured Pins       |
| CI/O            | Bidirectional Capacitance |     | 20  | pF   | Returned to Ground    |

#### Inputs

| tr | Any Input Rise Time | 100 | ns |  |
|----|---------------------|-----|----|--|
| tf | Any Input Fall Time | 100 | ns |  |

f = 1 MHz, over specified temperature range.

# **Z-BUS CPU Inteface Timing**

| Number | Symbol      | Parameter                                                     | Min  | Max | Units | Notes |
|--------|-------------|---------------------------------------------------------------|------|-----|-------|-------|
| 1      | TwAS        | AS Low Width                                                  | 70   |     | ns    |       |
| 2      | TsA(AS)     | Address to AS † Setup Time                                    | 10   |     | ns    | 1     |
| 3      | ThA(AS)     | Address to $\overline{\mathrm{AS}}$ † Hold Time               | 50   |     | ns    | 1     |
| 4      | TsCSO(AS)   | $\overline{\text{CS}}$ to $\overline{\text{AS}}$ † Setup Time | 0    |     | ns    | 1     |
| 5      | -ThCSO(AS)  | - CS to AS † Hold Time                                        |      |     | ns    | 1     |
| 6      | TdAS(DS)    | $\overline{\text{AS}}$ † to $\overline{\text{DS}}$ † Delay    | 60   |     | ns    | 1     |
| 7      | TsA(DS)     | Address to DS ↓                                               | 120  |     | ns    |       |
| 8      | TsRWR(DS)   | R/₩ (Read) to DS ↓ Setup Time                                 | 100  |     | ns    |       |
| 9      | TsRWW(DS)   | R/₩ (Write) to DS ↓ Setup Time                                | 0    |     | ns    |       |
| 10     | -TwDS       | - DS Low Width                                                |      |     | —ns — |       |
| 11     | TsDW(DSf)   | Write Data to DS ↓ Setup Time                                 | 30   |     | ns    |       |
| 12     | TdDS(DRV)   | DS (Read) 4 to Address Data Bus Driven                        | 0    |     | ns    |       |
| 13     | TdDSf(DR)   | DS I to Read Data Valid Delay                                 |      | 255 | ns    |       |
| 14     | ThDW(DS)    | Write Data to DS † Hold Time                                  | 30   |     | ns    |       |
| 15 —   | - TdDSr(DR) | - DS † to Read Data Not Valid Delay                           | 0-   |     | ns    |       |
| 16     | TdDS(DRz)   | DS † to Read Data Float Delay                                 |      | 70  | ns    | 2     |
| 17     | ThRW(DS)    | $R/\overline{W}$ to $\overline{DS}$ † Hold Time               | 60   |     | ns    |       |
| 18     | TdDS(AS)    | DS † to AS ↓ Delay                                            | 50   |     | ns    |       |
| 19     | Trc         | Valid Access Recovery Time                                    | 1000 |     | ns    | 3     |

NOTES:

3. This is the delay from  $\overline{\text{DS}}$  of one CIO access to  $\overline{\text{DS}}$  of another FIO access (either read or write).

transactions.
2. Float delay is measured to the time when the output has changed 0.5 V from steady state with minimum ac load and maximum dc load.

<sup>1.</sup> Parameter does not apply to Interrupt Acknowledge transactions.



# Z-BUS CPU Inteface Timing (Continued)



# Z-BUS CPU Interrupt Acknowledge Timing

| Number | Symbol       | Parameter                                                                    | Min | Max     | Units | Notes    |
|--------|--------------|------------------------------------------------------------------------------|-----|---------|-------|----------|
| 20     | TsIA(AS)     | INTACK to AS † Setup Time                                                    | 0   |         | ns    |          |
| 21     | ThIA(AS)     | INTACK to AS † Hold Time                                                     | 250 |         | ns    |          |
| 22     | TdDSA(DR)    | $\overline{\mathrm{DS}}$ (Acknowledge) $\downarrow$ to Read Data Valid Delay |     | 360     | ns    |          |
| 23     | TwDSA        | DS (Acknowledge) Low Width                                                   | 475 |         | ns    |          |
| 24     | -TdAS(IEO)—— | - AS ↓ to IEO ↓ Delay (INTACK Cycle)                                         |     | - 350 - | ns    | <u> </u> |
| 25     | TdIEI(IEO)   | IEI to IEO Delay                                                             |     | 150     | ns    | 4        |
| 26     | TsIEI(DSA)   | IEI to DS (Acknowledge) ↓ Setup Time                                         | 100 |         | ns    |          |
| 27     | ThIEI(DSA)   | IEI to DS (Acknowledge) ↓ Hold Time                                          | 200 |         | ns    | 4        |
| 28     | TdDS(INT)    | DS (INTACK Cycle) to INT Delay                                               |     |         | ns    |          |
| 29     | TdDCST       | Interrupt Daisy Chain Settle Time                                            |     |         | ns    | 4        |

NOTES:

4. The parameters for the devices in any particular daisy chain must meet the following constraint: The delay from  $\overline{AS}$  to  $\overline{DS}$  must be greater than the sum of TdAS(IEO) for the highest

priority peripheral, TsIEI(DSA) for the lowest priority peripheral, and TdIEI(IEO) for each peripheral separating them in the chain.





# **Z-BUS Interrupt Timing**

| Number | Symbol     | Parameter                                               | Min | Μαχ | Units Notes                                                |
|--------|------------|---------------------------------------------------------|-----|-----|------------------------------------------------------------|
| 30     | TdMW(INT)  | Message Write to INT Delay                              |     | 1   | AS Cycles 5                                                |
| 31     | TdDC(INT)  | Data Direction Change to INT Delay                      |     | 1   | $\frac{+ \text{ ns}}{\text{AS}}$ Cycles 6                  |
| 32     | TdPMW(INT) | Pattern Match to INT Delay (Write Case)                 |     | 1   | $\frac{+ \text{ ns}}{\text{AS}}$ Cycles                    |
| 33     | TdPMR(INT) | Pattern Match (Read Case) to INT Delay                  |     | 1   | $\frac{+ \text{ ns}}{\overline{\text{AS}} \text{ Cycles}}$ |
| 34——   | -TdSC(INT) | -Status Compare to INT Delay                            |     | 1   | $-\overline{\text{AS}}$ Cycles $-6$ $$                     |
| 35     | TdER(INT)  | Error to INT Delay                                      |     | 1   | $+ ns$ $\overline{AS}$ Cycles                              |
| 36     | TdEM(INT)  | Empty to INT Delay                                      |     | 1   | + ns<br>AS Cycles 6                                        |
| 37     | TdFL(INT)  | Full to INT Delay                                       |     | 1   | $\frac{+ \text{ ns}}{\text{AS}}$ Cycles 6                  |
| 38     | TdAS(INT)  | $\overline{\text{AS}}$ to $\overline{\text{INT}}$ Delay |     |     | $\overline{AS}$ Cycles                                     |
|        |            |                                                         |     |     | + ns                                                       |

NOTES: 5. Write is from the other side of FIO.

6. Write can be from either side, depending on programming of FIO. 1

|                             |                                     | +              |
|-----------------------------|-------------------------------------|----------------|
| MESSAGE<br>Write            | WRITE<br>MESSAGE<br>REGISTER<br>OUT |                |
| DATA<br>DIRECTION<br>CHANGE | WRITE<br>CONTROL<br>REGISTER 3      |                |
| PATTERN                     | WRITE DATA<br>BUFFER<br>REGISTER    |                |
| MATCH                       | READ DATA<br>BUFFER<br>REGISTER     | <u>Ds</u>      |
| STATUS<br>Compare           | WRITE DATA<br>BUFFER<br>REGISTER    | DS* (H)        |
| ERROR                       | WRITE DATA<br>BUFFER<br>REGISTER    | <u>Ds</u>      |
| EMPTY                       | WRITE DATA<br>BUFFER<br>REGISTER    | <u>D5</u> *(8) |
| FULL                        | WRITE DATA<br>BUFFER<br>REGISTER    | D5°            |
| ĀS                          |                                     | 3              |
| INT                         |                                     |                |

# Z-BUS Request/Wait Timing

| Number | Symbol      | Parameter                  | Min     | Max | Units | Notes  |
|--------|-------------|----------------------------|---------|-----|-------|--------|
| 1      | TdDS(WAIT)  | DS + to WAIT + Delay       |         |     | ns    |        |
| 2      | TdDS1(WAIT) | DSI ↓ to WAIT ↑ Delay      |         |     | ns    |        |
| 3      | TdACK(WAIT) | ACKIN ↓ to WAIT ↑ Delay    |         |     | ns    | 1      |
| 4 —    | - TdDS(REQ) | - DS ↓ to REQ ↑ Delay      |         |     | ns    |        |
| 5      | TdDMA(REQ)  | DMASTB + to REQ † Delay    |         |     | ns    |        |
| 6      | TdDS1(REQ)  | DSI † to REQ ↓ Delay       |         |     | ns    |        |
| 7      | TdACK(REQ)  | ACKIN ↓ to REQ ↓ Delay     |         |     | ns    |        |
| 8      | - TdSU(DMA) | Data Setup Time to DMASTB  | - 200 - |     | ns    | ······ |
| 9      | TdH(DMA)    | Data Hold Time to DMASTB   | 30      |     | ns    |        |
| 10     | TdDMA(DR)   | DMASTB 4 to Valid Data     |         |     | ns    |        |
| 11     | TdDMA(DRH)  | DMASTB † to Data Not Valid | 0       |     | ns    |        |
| 12     | TdDMA(DR2)  | DMASTB † to Data Bus Float |         | 70  | ns    |        |

#### NOTES:

1. The delay is from  $\overline{DAV} \downarrow$  for 3-Wire Input Handshake. The delay is from DAC 1 for 3-Wire Output Handshake.





### **Z-BUS Reset Timing**

| Number | Symbol      | Parameter                                                                             | Min | Μαχ | Units | Notes |
|--------|-------------|---------------------------------------------------------------------------------------|-----|-----|-------|-------|
| 1      | TdDSQ(AS)   | Delay from DS ↑ to AS ↓ for No Reset                                                  | 40  |     | ns    |       |
| 2      | TdASQ(DS)   | Delay for $\overline{AS}$ † to $\overline{DS} \downarrow$ for No Reset                | 50  |     | ns    |       |
| 3      | Tw(AS + DS) | Minimum Width of $\overline{\text{AS}}$ and $\overline{\text{DS}}$ Both Low for Reset | 500 |     | ns    | 1     |

NOTES:

1. Internal circuitry allows for the reset provided by the Z8  $(\overline{DS} \text{ held Low while AS pulses})$  to be sufficient.



### Non-Z-BUS CPU Interface Timing

| Number | Symbol           | Parameter                                                                        | Min   | Μαχ | Units  | Notes |
|--------|------------------|----------------------------------------------------------------------------------|-------|-----|--------|-------|
| 1      | TsA(RD)          | Address Setup to RD ↓                                                            | 80    |     | ns     | 1     |
| 2      | TsA(WR)          | Address Setup to WR ↓                                                            | 80    |     | ns     |       |
| З      | Th <b>A</b> (RD) | Address Hold Time to $\overline{\text{RD}}$ t                                    | 0     |     | ns     | 1     |
| 4      | -ThA(WR)         | - Address Hold Time to WR 1                                                      | 0 -   |     | ns     |       |
| 5      | TsCEI(RD)        | $\overline{\operatorname{CE}}$ Low Setup Time to $\overline{\operatorname{RD}}$  | 0     |     | ns     | 1     |
| 6      | TsCEI(WR)        | $\overline{\operatorname{CE}}$ Low Setup Time to $\overline{\operatorname{WR}}$  | 0     |     | ns     |       |
| 7      | ThCEI(RD)        | $\overline{\operatorname{CE}}$ Low Hold Time to $\overline{\operatorname{RD}}$   | 0     |     | ns     | 1     |
| 8      | -ThCEI(WR)       | - CE Low Hold Time to WR                                                         | 0 -   |     | — ns — |       |
| 9      | TsCEh(RD)        | $\overline{\operatorname{CE}}$ High Setup Time to $\overline{\operatorname{RD}}$ | 100   |     | ns     | 1     |
| 10     | TsCEh(WR)        | $\overline{\operatorname{CE}}$ High Setup Time to $\overline{\operatorname{WR}}$ | 100   |     | ns     |       |
| 11     | TwRD1            | RD Low Width                                                                     | 400   |     | ns     |       |
| 12     | - TdRD(DRA)      | — RD ↓ to Read Data Active Delay                                                 | 0 -   |     | — ns — |       |
| 13     | TdRDf(DR)        | RD ↓ to Valid Data Delay                                                         |       | 300 | ns     |       |
| 14     | TdRDr(DR)        | RD † to Read Data Not Valid Delay                                                | 0     |     | ns     |       |
| 15     | TdRD(DRz)        | RD ↑ to Data Bus Float                                                           |       | 70  | ns     | 2     |
| 16     | - TwWR1          | - WR Low Width                                                                   | 400 - |     | — ns — |       |
| 17     | TsDW(WR)         | Data Setup Time to $\overline{WR}$                                               | 0     |     | ns     |       |
| 18     | ThDW(WR)         | Data Hold Time to WR                                                             | 0     |     | ns     |       |
| 19     | Trc              | Valid Access Recovery Time                                                       | 1000  |     | ns     | 3     |

NOTES:

1. Parameter does not apply to Interrupt Acknowledge transactions.

3. This is the delay from  $\overline{\text{RD}}$  † or  $\overline{\text{WR}}$  † of one FIO access to  $\overline{\text{RD}}$  ↓ or  $\overline{\text{WR}}$  ↓ of another FIO access.

2. Float delay is measured to the time the output has changed 0.5 V from steady state with minimum ac load and maximum dc load.



Non-Z-BUS CPU Interface Timing(Continued)



Non-Z-BUS CPU Interface Timing



Non-Z-BUS Interface Timing



| Number | Symbol     | Parameter                                                | Min   | Μαχ | Units | Notes |
|--------|------------|----------------------------------------------------------|-------|-----|-------|-------|
| 20     | TdIEI(IEO) | IEI to IEO Delay                                         | 150   |     | ns    | 4     |
| 21     | TdI(IEO)   | INTACK   to IEO   Delay                                  | 350   |     | ns    | 4     |
| 22     | TsIEI(RDA) | IEI Setup Time to $\overline{\mathrm{RD}}$ (Acknowledge) | 200   |     | ns    | 4     |
| 23     | TdRD(DR)   | RD ↓ to Vector Valid Delay                               |       | 300 | ns    |       |
| 24     | -TwRD1(IA) | — Read Low Width (Interrupt Acknowledge) ——              | 400 - |     | ns    |       |
| 25     | ThIA(RD)   | INTACK † to RD † Hold Time                               | 30    |     | ns    |       |
| 26     | ThIEI(RD)  | IEI Hold Time to $\overline{RD}$ †                       | 100   |     | ns    |       |
| 27     | TdRD(INT)  | RD † to INT † Delay                                      |       |     | ns    |       |
| 28     | TdDCST     | Interrupt Daisy Chain Settle Time                        |       |     | ns    | 4     |

### Non-Z-BUS Interrupt Acknowledge Timing

NOTES:

 The parameter for the devices in any particular daisy chain must meet the following constraint: The delay from INTACK 4 to RD 4 must be greater than the sum of TdINA(IEO) for the highest priority peripheral, TsIEI(RD) for the lowest priority peripheral, and TdIEI(IEO) for each peripheral separating them in the chain.



# **Non-Z-BUS Interrupt Timing**

| Number | Symbol     | Parameter                               | Min | Max | Units | Notes |
|--------|------------|-----------------------------------------|-----|-----|-------|-------|
| 29     | TdMW(INT)  | Message Write to INT Delay              |     |     | ns    | 5,6   |
| 30     | TdDC(INT)  | Data Direction Change to INT Delay      |     |     | ns    | 5,7   |
| 31     | TdPMW(INT) | Pattern Match (Write Case) to INT Delay |     |     | ns    | 5     |
| 32     | TdPMR(INT) | Pattern Match (Read Case) to INT Delay  |     |     | ns    | 5     |
| 33     | -TdSC(INT) | – Status Compare to INT Delay ––––––    |     |     | ns    |       |
| 34     | TdER(INT)  | Error to INT Delay                      |     |     | ns    | 5,7   |
| 35     | TdEM(INT)  | Empty to INT Delay                      |     |     | ns    | 5,7   |
| 36     | TdFL(INT)  | Full to INT Delay                       |     |     | ns    | 5,7   |
| 37     | TdSO(INT)  | State 0 to INT Delay                    |     |     | ns    |       |

NOTES:

\_

5. Delay number is valid for State 0 only.

6. Write is from other side of FIO.

7. Write can be from either side, depending on programming of FIO.





# Non-Z-BUS Request/Wait Timing

| Number | Symbol     | Parameter                                                                                              | Min | Μαχ | Units  | Notes |
|--------|------------|--------------------------------------------------------------------------------------------------------|-----|-----|--------|-------|
| 1      | TdRD(WT)   | RD I to WAIT Active                                                                                    |     |     | ns     |       |
| 2      | TdRD1(WT)  | RD1 ↓ to WAIT Inactive                                                                                 |     |     | ns     |       |
| 3      | TdACK(WT)  | ACKIN I to WAIT Inactive                                                                               |     |     | ns     | 1     |
| 4      | -TdRD(REQ) | -RD ↓ to REQ Inactive                                                                                  |     |     | — ns — |       |
| 5      | TdRD1(REQ) | RD1 4 to REQ Active                                                                                    |     |     | ns     |       |
| 6      | TdACK(REQ) | ACKIN I to REQ Active                                                                                  |     |     | ns     |       |
| 7      | TdDAC(RD)  | $\overline{DACK} \downarrow \text{ to } \overline{RD} \downarrow \text{ or } \overline{WR} \downarrow$ |     |     | ns     |       |
| 8      | -TSU(WR)   | – Data Setup Time to WR                                                                                |     |     | — ns — |       |
| 9      | Th(WR)     | Data Hold Time to WR                                                                                   |     |     | ns     |       |
| 10     | TdDMA      | RD ↓ to Valid Data                                                                                     |     |     | ns     | 2     |
| 11     | TdDMA(DRH) | RD † to Data Not Valid                                                                                 | 0   |     | ns     | 2     |
| 12     | TdDMA(DRZ) | RD † to Data Bus Float                                                                                 |     | 70  | ns     | 2     |

#### NOTES:

The delay is from DAV 4 for 3-Wire Input Handshake. The delay is from DAC 1 for 3-Wire Input Handshake.

2. Only when DACK is active.





# Non-Z-BUS Reset Timing

| Number | Symbol    | Parameter                                                                       | Min | Max | Units |
|--------|-----------|---------------------------------------------------------------------------------|-----|-----|-------|
| 1.     | TdWR(RD)  | Delay from WR † to RD ↓                                                         | 100 |     | ns    |
| 2.     | TdRD(WR)  | Delay from $\overline{\mathrm{RD}}$ † to $\overline{\mathrm{WR}}$ ↓             | 100 |     | ns    |
| 3.     | TwRD + WR | Width of $\overline{\text{RD}}$ and $\overline{\text{WR}}$ , both Low for Reset | 500 |     | ns    |



# Port 2 Side Operation

| Number | Symbol    | Parameter                    | Min        | Max Unit | 8 |
|--------|-----------|------------------------------|------------|----------|---|
| 1.     | TwCLR     | Width of Clear to Reset FIFO | 700        | ns       |   |
| 2.     | TdOE(DO)  | OE ↓ to Data Bus Driven      | - <b>O</b> | ns       |   |
| з.     | TdOE(DRZ) | OE 1 to Data Bus Float       |            | ns       |   |





# FIO 2-Wire Handshake Timing

| Number | Symbol       | Parameter                                                           | Min | Μαχ                              | Units    |
|--------|--------------|---------------------------------------------------------------------|-----|----------------------------------|----------|
| 1      | TsDI(ACK)    | Data Input to ACKIN ↓ to Setup Time                                 |     |                                  | ns       |
| 2      | TdACKf(RFD)  | ACKIN ↓ to RFD ↓ Delay                                              | 0   |                                  | ns       |
| 3      | TdRFDr(ACK)  | RFD † to ACKIN ↓ Delay                                              | 0   |                                  | ns       |
| 4      | -TsDO(DAV) — | – Data Out to DAV I Setup Time –––––                                | 25  |                                  | — ns ——— |
| 5      | TdDAVf(ACK)  | DAV   to ACKIN   Delay                                              | 0   |                                  | ns       |
| 6      | ThDO(ACK)    | Data Out to ACKIN Hold Time                                         |     |                                  | ns       |
| 7      | TdACK(DAV)   | ACKIN 1 to DAV † Delay                                              | 0   |                                  | ns       |
| 8 —    | -ThDI(RFD)   | – Data Input to RFD ↓ Hold Time –––––                               | 0   | 4.00 - <b>4</b> .000 - 000 - 000 | ns       |
| 9      | TdRFDf(ACK)  | RFD↓ to ACKIN ↑ Delay                                               | 0   |                                  | ns       |
| 10     | TdACKr(RFD)  | ACKIN † (DAV †) to RFD † Delay—<br>Interlocked and 3-Wire Handshake | 0   |                                  | ns       |
| 11     | TdDAVr(ACK)  | DAV t to ACKIN t (RFD t)                                            | 0   |                                  | ns       |
| 12     | TdACKr(DAV)  | ACKIN t to DAV I                                                    | 0   |                                  | ns       |



2-Wire Handshake (Port 2 Side Only) Output



2-Wire Handshake (Port 2 Side Only) Input



# 3-Wire Handshake Timing

| Number | Symbol       | Parameter                      | Min | Max | Units |
|--------|--------------|--------------------------------|-----|-----|-------|
| 1      | TsDI(DAV)    | Data Input to DAV ↓ Setup Time |     |     | ns    |
| 2      | TdDAVIf(RFD) | DAV I to RFD I Delay           | 0   |     | ns    |
| 3      | TdDAVf(DAC)  | DAV I to DAC † Delay           | 0   |     | ns    |
| 4      | -ThDI(DAC)   | -Data In to DAC † Hold Time    | -0- |     | ns    |
| 5      | TdDACIr(DAV) | DAC † to DAV † Delay           | 0   |     | ns    |
| 6      | TdDAVIr(DAC) | DAV † to DAC ↓ Delay           | 0   |     | ns    |
| 7      | TdDAVIr(RFD) | DAV t to RFD t Delay           | 0   |     | ns    |
| 8      | -TdRFDI(DAV) | RFD † to DAV ↓ Delay           | 0   |     | ns    |
| 9      | TsDO(DAC)    | Data Out to DAV 1              |     |     | ns    |
| 10     | TdDAVOf(RFD) | DAV↓ to RFD↓ Delay             | 0   |     | ns    |
| 11     | TdDAVOf(DAC) | DAV I to DAC † Delay           | 0   |     | ns    |
| 12 —   | ThDO(DAC)    | Data Out to DAC † Hold Time    |     |     | ns    |
| 13     | TdDACOr(DAV) | DAC † to DAV † Delay           |     |     | ns    |
| 14     | TdDAVOr(DAC) | DAV † to DAC ↓ Delay           | 0   |     | ns    |
| 15     | TdDAVOr(RFD) | DAV † to RFD † Delay           | 0   |     | ns    |
| 16     | TdRFDO(DAV)  | RFD † to DAV ↓ Delay           | 0   |     | ns    |



3-Wire Handshake Input



3-Wire Handshake Output



# Ordering Information

| Туре      | Package        | Temp       | Clock | Description                 |
|-----------|----------------|------------|-------|-----------------------------|
| Z8538 B1  | Plastic 40 pin | 0/+70°C    |       | Z8538 FIO FIFO Input/Output |
| B6        | Plastic 40 pin | -40/+85°C  |       | Interface Unit.             |
| DI        | Ceramic 40 pin | 0/+70°C 🔰  | 4MHz  |                             |
| D2        | Ceramic 40 pin | -55/+125°C |       |                             |
| D6        | Ceramic 40 pin | 40/+85°C   |       |                             |
| Z8538A BI | Plastic 40 pin | 0/+70°C    |       |                             |
| B6        | Plastic 40 pin | -40/+85°C  | CMU-  |                             |
| D1        | Ceramic 40 pin | 0/+70°C    | 6MHz  |                             |
| D6        | Ceramic 40 pin | -40/+85°C  |       |                             |

# Packages

Plastic

Ceramic





# Universal Peripheral Controller



### Features

- Complete slave microcomputer, for distributed processing use.
- Unmatched power of Z8 architecture and instruction set.
- Three programmable I/O ports, two with optional 2-Wire Handshake.
- Six levels of priority interrupts from eight sources: six from external sources and two from internal sources.
- Two programmable 8-bit counter/timers

#### **General Description**

The Z8590 Universal Peripheral Controller (UPC) is an intelligent peripheral controller for distributed processing applications (Figure 3). The UPC unburdens the host processor by assuming tasks traditionally done by the host (or by added hardware), such as performing arithmetic, translating or formatting data, and controlling I/O devices. Based on the Z8 microcomputer architecture and instruction set, the UPC contains 2K bytes of internal proeach with a 6-bit prescaler. Counter/Timer T0 is driven by an internal source, and Counter/Timer T1 can be driven by internal or external sources. Both counter/timers are independent of program execution.

- 256-byte register file, accessible by both the master CPU and UPC, as allocated in the UPC program.
- 2K bytes of on-chip ROM for efficiency and versatility.

gram ROM, a 256-byte register file, three 8-bit I/O ports, and two counter/timers.

The UPC offers fast execution time, an effective use of memory, and sophisticated interrupt, I/O, and bit manipulation. Using a powerful and extensive instruction set combined with an efficient internal addressing scheme, the UPC speeds program execution and efficiently packs program code into the on-chip ROM.



Figure 1. Z8590 UPC Logic Functions



# General Description (Continued)

An important feature of the UPC is an internal register file containing I/O port and control registers accessed both by the UPC program and indirectly by its associated master CPU. This architecture results in both byte and programming efficiency, because UPC instructions can operate directly on I/O data without moving it to and from an accumulator. Such a structure allows the user to allocate as many general purpose registers as the application requires for data buffers between the CPU and peripheral devices. All general-purpose registers can be used as address pointers, index registers, data buffers, or stack space.

The register file is logically divided into 16 groups, each consisting of 16 working registers. A Register Pointer is used in conjunction with short format instructions, resulting in tight, fast code and easy task switching.

Communication between the master CPU

and the register file takes place via one group of 19 interface registers addressed directly by both the master CPU and the UPC, or via a block transfer mechanism. Access by the master CPU is controlled by the UPC to allow independence between the master CPU and UPC software.

The UPC has 24 pins that can be dedicated to I/O functions. Grouped logically into three 8-line ports, they can be programmed in many combinations of input or output lines, with or without handshake, and with push-pull or open-drain outputs. Ports 1 and 2 are bitprogrammable; Port 3 has four fixed inputs and four outputs.

To relieve software from coping with realtime counting and timing problems, the UPC has two 8-bit hardware counter/timers, each with a fixed divide-by-four, and a 6-bit programmable prescaler. Various counting modes may be selected.







# General Description (Continued)

In addition to the 40-pin standard configuration, the UPC is available in four special configurations:

- A 64-pin RAM development version with external interface for up to 4K bytes of RAM and 36 bytes of internal ROM permitting down-loading from the master CPU.
- A Protopack RAM version with a socket for up to 2K bytes of RAM, with 36 bytes of internal ROM permitting down-loading from the master CPU.
- A 64-pin ROM development version with external interface for up to 4K bytes of ROM and no internal ROM.
- A Protopack ROM version with a socket for 2K bytes of ROM and no internal ROM.

This range of versions and configurations makes the UPC compatible with most system peripheral device control considerations.

### **Pin Description**

**Ā/D.** Address/Data (input). A Low on this pin defines information on the data bus as an address. A High defines the information as data.

**CS.** Chip Select (input, active Low). A Low enables the UPC to accept address or data information from the master CPU during a write cycle or to transmit data to the master CPU during a read cycle. This line is usually generated from higher bits of the address lines.

**DB**<sub>0</sub>-**DB**<sub>7</sub>. Data Bus (bidirectional). This bus is used to transfer address and data information between the master CPU and the UPC.

**P1<sub>0</sub>-P17, P2<sub>0</sub>-P27, P3<sub>0</sub>-P37.** *I/O Port Lines* (bidirectional, TTL compatible). These 24 lines are divided into three 8-bit I/O ports and may be configured in the following ways under program control:

**Pl<sub>0</sub>-Pl<sub>7</sub>.** *Port 1* (input/output—as output it can be push-pull or open-drain). Bit-programmable Parallel I/O.

P20-P27. Port 2 (input/output-as output, it can

### **Functional Description**

**Address Space.** On the 40-pin UPC, all address space is committed to on-chip memory. There are 2048 bytes of maskprogrammed ROM and 256 bytes of register be push-pull or open-drain). Bit-programmable Parallel I/O.

**P30-P37.** *Port 3* (four inputs, four outputs). Parallel I/O, handshake control, timer I/O, or interrupt control.

**PCLK.** Clock (input). TTL-compatible clock input, 4 MHz maximum. This signal does not need to be related to the master CPU clock.

**RD.** Read (input, active Low). A Low enables the master CPU to read information from the UPC. Raising the voltage on this pin above  $V_{DD}$  will force the UPC into test mode.

**WAIT.** Wait (output, active Low, open-drain). When the CPU accesses the UPC register file, this signal requests the master CPU to wait until the UPC can complete its part of the transaction.

**WR.** Write (input, active Low). A Low on this pin enables the master CPU to write information to the UPC. A simultaneous Low on  $\overline{RD}$  and  $\overline{WR}$  resets the UPC. It is held in reset as long as  $\overline{WR}$  is Low.

file. I/O is memory-mapped to three registers in the register file. Only the Protopack and 64-pin versions of the UPC can access external program memory. See the section entitled



"Special Configurations" for complete descriptions of the Protopack and 64-pin versions. *Program Memory.* Figure 4 is a map of the 2K on-chip program ROM. Even though the architecture allows addresses from 0 to 4K, behavior of the device above program address 2047 (7FFH) is not defined. The first 12 bytes of program memory are reserved for the UPC interrupt vectors. For the Protopack and 64-pin



Figure 4. Program Memory Map

versions, the address space is extended to 4096 bytes. In the RAM versions, addresses 0CH through 2FH are reserved for on-chip ROM.

Register File. This 256-byte file includes three I/O port registers (1-3H), 234 general-purpose registers (6-EEH), and 19 control, status and special I/O registers (0H, 4H, 5H, and F0-FFH). The functions and mnemonics assigned to these register address locations are shown in Figure 5. Of the 256 UPC registers, 19 can be directly accessed by the master CPU; the others are accessed indirectly via the block transfer mechanism.

The I/O port and control registers are included in the register file without differentiation. This allows any UPC instruction to process I/O or control information, thereby eliminating the need for special I/O and control instructions. All general-purpose registers can function as accumulators, address pointers, or index registers. In instruction exe-

| LOCATION |                                  | IDENTIFIER<br>(UPC Side) |
|----------|----------------------------------|--------------------------|
| FFH      | STACK POINTER                    | SP                       |
| FEH      | MASTER CPU INTERRUPT CONTROL     | MIC                      |
| FDH      | REGISTER POINTER                 | RP                       |
| FCH      | PROGRAM CONTROL FLAGS            | FLAGS                    |
| FBH      | UPC INTERRUPT MASK REGISTER      | IMR                      |
| FAH      | UPC INTERRUPT REQUEST REGISTER   | IRQ                      |
| F9H      | UPC INTERRUPT PRIORITY REGISTER  | IPR                      |
| F8H      | PORT 1 MODE                      | P1M                      |
| F7H      | PORT 3 MODE                      | РЗМ                      |
| F6H      | PORT 2 MODE                      | P2M                      |
| F5H      | T <sub>0</sub> PRESCALER         | PRE0                     |
| F4H      | TIMER/COUNTER 0                  | To                       |
| F3H      | T1 PRESCALER                     | PRE1                     |
| F2H      | TIMER/COUNTER 1                  | τ1                       |
| F1H      | TIMER MODE                       | TMR                      |
| FOH      | MASTER CPU INTERRUPT VECTOR REG. | MIV                      |
| EFH      | GENERAL-PURPOSE REGISTERS        |                          |
| 6H       |                                  |                          |
| 5H       | DATA INDIRECTION REGISTER        | DIND                     |
| 4H       | LIMIT COUNT REGISTER             | LC                       |
| зн       | PORT 3                           | P3                       |
| 2H       | PORT 2                           | P2                       |
| 1H       | PORT 1                           | P1                       |
| он       | DATA TRANSFER CONTROL REGISTER   | DTC                      |

Figure 5. Register File Organization

cution, the registers are read when they are defined as sources and written when defined as destinations.

UPC instructions may access registers directly or indirectly using an 8-bit address mode or a 4-bit address mode and a Register Pointer. For the 4-bit addressing mode, the file is divided into 16 working register groups, each occupying 16 contiguous locations (Figure 6). The Register Pointer (RP) addresses the starting point of the active working-register group, and the 4-bit register designator supplied by the instruction specifies the register within the group. Any instruction altering the contents of the register file can also alter the Register Pointer. The UPC instruction set has a special Set Register Pointer (SRP) instruction for initializing or altering the pointer contents.

*Stacks.* An 8-bit Stack Pointer (SP), register R255, is used for addressing the stack, residing within the 234 general-purpose



Figure 6. Register Pointer Mechanism

registers, address location 6H through EFH. PUSH and POP instructions can save and restore any register in the register file on the stack. During CALL instructions, the Program Counter is automatically saved on the stack. During UPC interrupt cycles, the Program Counter and the Flag register are automatically saved on the stack. The RET and IRET instructions pop the saved values of the Program Counter and Flag register.

**Ports.** The UPC has 24 lines dedicated to input and output. These are grouped into three ports of eight lines each and can be configured under software control as inputs, outputs, or special control signals. They can be programmed to provide Parallel I/O with or without handshake and timing signals. All outputs can have active pullups and pulldowns, compatible with TTL loads. In addition, they may be configured as open-drain outputs.

*Port 1.* Individual bits of Port 1 can be configured as input or output by programming Port 1 Mode register (P1M) F8H. This port is accessed by the UPC program as general register 1H. It is written by specifying address 1H as the destination of any instruction used to store data in the output register. The port is read by specifying address 1H as the source of an instruction.

78590 UPC

Port 1 may be placed under handshake control by programming Port 3 Mode register (P3M) F7H. This configures Port 3 pins P3<sub>3</sub> and P3<sub>4</sub> as handshake control lines  $\overline{DAV_1}$  and  $RDY_1$  for input handshake, or  $RDY_1$  and  $\overline{DAV_1}$ for output handshake, as determined by the direction (input or output) assigned to bit 7 of Port 1. The Port 3 Mode register also has a bit that programs Port 1 for open-drain output.

*Port 2.* Individual bits of Port 2 can be configured as inputs or outputs by programming Port 2 Mode register (P2M) F6H. This port is accessed by the UPC program as general register 2H, and its functions and methods of programming are the same as those of Port 1.



Port 3 pins P3<sub>1</sub> and P3<sub>6</sub> are the handshake lines  $\overline{DAV}_2$  and  $RDY_2$ , with the direction (input or output) determined by the state of bit 7 of the port. The Port 3 Mode register also has a bit used to program Port 2 for open-drain output.

*Port 3.* This port can be configured as I/O or control lines by programming the Port 3 Mode register. Port 3 is accessed as general register 3H. The directions of the eight data lines are fixed. Four lines, P3<sub>0</sub> through P3<sub>3</sub>, are inputs, and the other four, P3<sub>4</sub> through P3<sub>7</sub>, are outputs. The control functions performed by Port 3 are listed in Table 1.

**Counter/Timers.** The UPC contains two 8-bit programmable counter/timers, each driven by an internal 6-bit programmable prescaler.

The T1 prescaler can be driven by internal or external clock sources. The T0 prescaler is driven by an internal clock source. Both counter/timers operate independently of the program from time-critical operations like event counting or elapsed-time calculation. T0 Prescaler register (PRE0) F5H and T1 Prescaler register (PRE1) F3H can be programmed to divide the input frequency of the source being counted by any number from 1 to 64. A

| Function                  | Line                                                                       | Direction              | Signal                                                                                                    |
|---------------------------|----------------------------------------------------------------------------|------------------------|-----------------------------------------------------------------------------------------------------------|
| Handshake ·               | ( P3 <sub>1</sub><br>P3 <sub>3</sub><br>P3 <sub>4</sub><br>P3 <sub>6</sub> | In<br>In<br>Out<br>Out | $\frac{\overline{DAV}_2/RDY_2}{DAV_1/RDY_1}$ $\frac{RDY_1}{RDY_1/\overline{DAV}_1}$ $\frac{RDY_2}{RDY_2}$ |
| UPC Interrupt<br>Request* | P30<br>P31<br>P33                                                          | In<br>In<br>In         | IRQ <sub>3</sub><br>IRQ <sub>2</sub><br>IRQ <sub>1</sub>                                                  |
| Counter/Timer             | ( P3 <sub>1</sub><br>P3 <sub>6</sub>                                       | In<br>Out              | T <sub>7N</sub><br>T <sub>OUT</sub>                                                                       |
| Master CPU                | P35<br>P32<br>P30<br>P37                                                   | Out<br>In<br>In<br>Out | INT<br>INTACK<br>IEI<br>IEO                                                                               |
| Test Mode                 | P35                                                                        | Out                    | Ā/D                                                                                                       |

\*P3<sub>0</sub>, P3<sub>1</sub>, and P3<sub>3</sub> can always be used as UPC interrupt request inputs, regardless of the configuration programmed.

Table 1. Port 3 Control Functions

counter register (F2H or F4H) is loaded with a number from 1 to 256. The corresponding counter is decremented from this number each time the prescaler reaches end-of-count. When the count is complete, the counter issues a timer interrupt request;  $IRQ_4$  for T0 or  $IRQ_5$  for T1. Loading either counter with a number (n) results in the interruption of the UPC at the nth count.

The counters can be started, stopped, restarted to continue, or restarted from the initial value. They can be programmed to stop upon reaching end-of-count (Single-Pass mode) or to automatically reload the initial value and continue counting (Modulo-n Continuous mode). The counters and prescalers can be read at any time without disturbing their values or changing their counts. The clock sources for both timers can be defined as any one of the following:

- UPC internal clock (4 MHz maximum) divided by four.
- External clock input to Counter/Timer T1 via P3<sub>1</sub> (1 MHz maximum).
- Retriggerable trigger input for the UPC internal clock divided by four.
- Nonretriggerable trigger input for the UPC internal clock divided by four.
- External gate input for the UPC internal clock divided by four.

**Interrupts.** The UPC allows six interrupts from eight different sources as follows:

- Port 3 lines P30, P32, and P33.
- The master CPU(3).
- The two counter/timers.

These interrupts can be masked and globally enabled or disabled using Interrupt Mask Register (IMR) FBH. Interrupt Priority Register (IPR) F9H specifies the order of their priority. All UPC interrupts are vectored.

Table 2 lists the UPC's interrupt sources, their types, and their vector locations in program ROM. Interrupt Request IRQ<sub>6</sub> is dedicated to master CPU communications.

| Name             | Source                                                         | Vector<br>Location | Comments                                     |
|------------------|----------------------------------------------------------------|--------------------|----------------------------------------------|
| IRQ <sub>0</sub> | EOM, XERR, LERR                                                | 0,1                | Internal (RO Bits 0, 1, 2)                   |
| IRQ1             | $\overline{\text{DAV}}_1$ , IRQ <sub>1</sub>                   | 2,3                | External (P33) ↓ Edge Triggered              |
| IRQ2             | $\overline{\text{DAV}}_2$ , IRQ <sub>2</sub> , T <sub>IN</sub> | 4,5                | External (P31) ↓ Edge Triggered              |
| IRQ3             | IRQ <sub>3</sub> , IEI                                         | 6,7                | External (P3 <sub>0</sub> ) ↓ Edge Triggered |
| IRQ4             | ТО                                                             | 8,9                | Internal                                     |
| IRQ5             | T1                                                             | 10,11              | Internal                                     |

#### Table 2. Interrupt Types, Sources, and Vector Locations

Interrupt Requests  $IRQ_1$ ,  $IRQ_2$ , and  $IRQ_3$  are generated on the falling transitions of external inputs P3<sub>3</sub>, P3<sub>1</sub>, and P3<sub>0</sub>. Interrupt Requests  $IRQ_4$  and  $IRQ_5$  are generated upon the timeout of the UPC's two counter/timers. When an interrupt request is granted, the UPC enters an interrupt machine cycle. This cycle disables all subsequent interrupts, saves the Program Counter and Status Flags, and branches to the program memory vector location reserved for that interrupt. This memory location and the next byte contain the 16-bit address of the interrupt service routine for that particular interrupt request.

The UPC also supports polled systems. To accommodate a polled structure, any or all of the interrupt inputs can be masked and the Interrupt Request register polled to determine which of the interrupt reguests needs service.

Following any hardware reset operation, an EI instruction must be executed to enable the setting of any interrupt request bit in the IRQ register. Interrupts must be disabled prior to changing the content of either the IPR (F9H) or the IMR (FBH). DI is the only instruction that should be used to globally disable interrupts.

**Master CPU Register File Access.** There are two ways in which the master CPU can access the UPC register file: direct access and block access.

*Direct Access.* Three UPC registers—the Data Transfer Control (0H), the Master Interrupt Vector (F0H), and the Master Interrupt Control (FEH)—are mapped directly into the master CPU address space. The master CPU accesses these registers via the addresses shown in Table 3.

78590 UPC

| UPC A   | ldress |                        |                  |
|---------|--------|------------------------|------------------|
| Decimal | Hex    | Identifie <del>r</del> | Address          |
| 0       | 0H     | DTC                    | xxx11000         |
| 5       | 5H     | DIND                   |                  |
| @5**    | @5H**  |                        | xxxlllll         |
| 240     | FOH    | MIV                    | xxx10000         |
| 254     | FEH    | MIC                    | xxx11110         |
| 'n      |        | DSC0                   | xxx00000         |
| n + 1   |        | DSC1                   | xxx00001         |
| n + 2   |        | DSC2                   | <b>xxx</b> 00010 |
| n + 3   |        | DSC3                   | xxx00011         |
| n + 4   |        | DSC4                   | xxx00100         |
| n + 5   |        | DSC5                   | xxx00101         |
| n + 6   |        | DSC6                   | xxx00110         |
| n + 7   |        | DSC7                   | <b>xxx</b> 00111 |
| n + 8   |        | DSC8                   | xxx01000         |
| n + 9   |        | DSC9                   | xxx01001         |
| n + 10  |        | DSCA                   | xxx01010         |
| n+11    |        | DSCB                   | xxx01011         |
| n + 12  |        | DSCC                   | xxx01100         |
| n + 13  |        | DSCD                   | xxx01101         |
| n + 14  |        | DSCE                   | <b>xxx</b> 01110 |
| n + 15  |        | DSCF                   | xxx01111         |

x = don't care

\*n is the value in the IRP x 16

\*\*Master CPU accesses the register address in Register 5.

Table 3. Master CPU/UPC Register Map



The master CPU also has direct access to 16 registers known as the DSC (Data, Status, Command) registers. The DSC registers are numbered 0 through F (DSC0-DSCF). These registers can be any 16 contiguous register file registers beginning on a 16-byte boundary. The base address of the DSC register group is designated by the IRP (I/O Register Pointer), which is bits  $D_4$ - $D_7$  of the Data Transfer Control register (OH). Figure 7 shows how the register address is made up of the 4-bit IRP field, concatenated with the low order 4-bits of the address from the master CPU.

Block Access. The master CPU may transmit or receive blocks of data via address xxx11111. When the master CPU accesses this address. the UPC register pointed to by the Data Indirection register is read or written. The Data Indirection register is incremented, and the Limit Count register is decremented, for example, when the master CPU issues a read or write to address xxx11111 while the Data Indirection register contains the value 33H. The operation causes register 33H to be read or written and the Data Indirection register to be incremented to 34H. This scheme is well suited to Block I/O Instructions and allows the master CPU to efficiently read or write a block of data to or from the UPC.

The Limit Count register (04H) is decremented and is used to control the number of bytes to be transferred by master CPU block accesses. If the master CPU attempts a read or write to the UPC after the Limit Count register reaches 0, the access is

## **Special Configurations**

There are two piggyback and two 64-pin versions of the UPC. These versions are identical to the 40-pin UPC with the following exceptions:

 Internal ROM is totally omitted from the 64-pin development (Z8591) and piggyback ROM (Z8593) versions. not completed, the LERR bit  $(D_2)$  of the Data Transfer Control register is set (indicating a limit error), and the LERR error causes an  $IRQ_0$  interrupt request.

The IRP field of the Data Transfer Control register, the Data Indirection register, and the Limit Count register are not directly accessible to the master CPU and therefore must be set by the UPC. This allows the UPC to protect itself from master CPU errors and frees the master CPU from tracking the UPC's internal data layout.



Figure 7. DSC Register Addressing Scheme

- All but 36 bytes of internal ROM are omitted from the 64-pin RAM (Z8592) and piggyback (RAM) (Z8594) versions.
- The memory address and data lines are buffered and brought out to external pins or to the socket on the piggyback.
- Control lines for the external memory are also provided.



## Special Configurations (Continued)

The 64-pin version of the UPC allows the user to prototype the system in hardware with an actual UPC device and to develop the code intended to be mask programmed into the on-chip ROM of the 40-pin UPC for the production system. The 64-pin or piggyback RAM versions of the UPC are extremely versatile parts. Memory space can be extended to 4K bytes on the 64-pin version by using external RAM/ROM for all but 36 bytes of the UPC's memory space. This memory can then be down-loaded from the master CPU using a bootstrap program stored in the 36 bytes (C-2F). Figure 8 is a memory map for the 64-pin RAM version.



Figure 8. UPC RAM Version Memory Map

**64-Pin and Piggyback Pin Functions.** Forty of the pins on the 64-pin and piggyback versions have functions identical to those of the 40-pin version. The remaining 24 pins have additional functions described below. (Figures 9 through 11 show the 64-pin and piggyback versions' pin functions and pin assignments.)

**A<sub>0</sub>-A<sub>11</sub>.** Program Memory Address Lines (output). These lines are identical in all 64-pin and RAM versions in the piggyback. They are used to address 4K bytes of external UPC memory.

**D<sub>0</sub>-D<sub>7</sub>.** Program Data (input). Data is read in from the external memory on these lines. The RAM version also writes external memory through this bus.

**IACK.** Interrupt Acknowledge (output, active High). This signal is active whenever an internal UPC interrupt cycle is in process.

**MAS.** Memory Address Strobe (output, active Low). This address strobe is pulsed once for each memory fetch to interface with guasistatic RAM.

**MDS.** Memory Data Strobe (output, active Low). This signal is Low during an instruction fetch or memory write.



Figure 9. Z8591/Z8592 UPC Logic Functions



# Special Configurations (Continued)

**MR/W.** Memory Read/Write (output RAM versions only). This signal is High when the UPC is fetching an instruction and Low when it is loading external memory.

P31 64 +5 V P36 63 PCLK 2 62 P37/IEO P27 3 61 P30/IEI 60 P35/INT P26 4 P25 5 P24 59 P32/INTACK 6 P23 7 58 🗍 RD 57 WR P22 P21 9 P20 10 55 CS 54 WAIT P33 11 P34 12 53 DB7 P17 13 52 DB6 DB5 P16 🔲 14 51 78591 P15 15 P14 16 50 DB4 Z8592 DBa UPC 49 P13 17 48 GND P1<sub>2</sub> 18 P1<sub>1</sub> 19 47 DB2 46 DB1 P10 20 Пов₀ 45 44 SYNC D7 21 D6 22 D6 43 MAS 42 MDS D5 23 D4 24 41 MR/W/IACK 25 40 D<sub>0</sub> 39 D<sub>1</sub> A<sub>0</sub> 25 A<sub>1</sub> 26 38 [D2 A2 27 28 37 D<sub>3</sub> 36 A<sub>11</sub> A3 [ A4 ( 29 30 35 A10 A<sub>5</sub> 34 🗍 A9 31 A<sub>6</sub> 32 33 A<sub>7</sub> A

Figure 10. Z8591/Z8592 UPC Pin Configuration

## **Addressing Modes**

The following notation is used to describe the addressing modes and instruction operations as shown in the instruction summary.

- R Register or working-register address
- Working-register address only
- IR Indirect-register or indirect working-register address
- Ir Indirect working-register address only

**SYNC.** Instruction Sync (output, active Low). This signal is Low during the clock cycle just preceding an opcode fetch.



\*SOCKET FOR 2716 EPROM (2K × 8) OR RAM

#### Figure 11. Z8593/Z8594 UPC Piggyback EPROM/RAM Pin Configuration

- **RR** Register pair or working-register pair address
- IRR Indirect register pair or indirect working-register pair address
- Irr Indirect working-register pair only
- X Indexed address
- DA Direct address
- RA Relative address
- IM Immediate



### Additional Symbols

- dst Destination location or contents
- src Source location or contents
- cc Condition code (see list)
- @ Indirect address prefix
- SP Stack Pointer (control register FFH)
- PC Program Counter
- FLAGS Flag register (control register FCH)
- **RP** Register Pointer (control register FDH)
- IMR Interrupt Mask register (control register FBH)

Assignment of a value is indicated by the symbol ``— ''. For example,

### dst ← dst + src

indicates that the source data is added to the destination data and the result is stored in the destination location. The notation "addr(n)" is used to refer to bit "n" of a given location. For example, dst (7)

refers to bit 7 of the destination operand.

### Flags

Control Register FCH contains the following six flags:

- C Carry flag
- Z Zero flag
- S Sign flag
- V Overflow flag
- D Decimal-adjust flag
- H Half-carry flag

Condition Codes

Affected flags are indicated by:

- 0 Cleared to zero
- 1 Set to one
- Set or cleared according to operation
- Unaffected
- X Undefined

| Value | Mnemonic | Meaning                        | Flags Set               |
|-------|----------|--------------------------------|-------------------------|
| 1000  |          | Always true                    |                         |
| 0111  | С        | Carry                          | C = 1                   |
| 1111  | NC       | No carry                       | C = 0                   |
| 0110  | Z        | Zero                           | Z = 1                   |
| 1110  | NZ       | Not zero                       | Z = 0                   |
| 1101  | PL       | Plus                           | S = 0                   |
| 0101  | MI       | Minus                          | S = 1                   |
| 0100  | OV       | Overflow                       | V = 1                   |
| 1100  | NOV      | No overflow                    | V = 0                   |
| 0110  | EQ       | Equal                          | Z = 1                   |
| 1110  | NE       | Not equal                      | Z = 0                   |
| 1001  | GE       | Greater than or equal          | (S XOR V) = 0           |
| 0001  | LT       | Less than                      | (S XOR V) = 1           |
| 1010  | GT       | Greater than                   | [Z OR (S XOR V)] = 0    |
| 0010  | LE       | Less than or equal             | [Z OR (S XOR V)] = 1    |
| 1111  | UGE      | Unsigned greater than or equal | C = 0                   |
| 0111  | ULT      | Unsigned less than             | C = 1                   |
| 1011  | UGT      | Unsigned greater than          | (C = 0  AND  Z = 0) = 1 |
| 0011  | ULE      | Unsigned less than or equal    | (C  OR  Z) = 1          |
| 0000  |          | Never true                     |                         |



## Instruction Formats



CCF, DI, EI, IRET, NOP, RCF, RET, SCF

**One-Byte Instructions** 



**Two-Byte Instructions** 

**Three-Byte Instructions** 



# Opcode Map

Lower Nibble (Hex)

|                    |                   | 0                             | 1                                            | 2                              | 3                                              | 4                                                      | 5                                                       | 6                                  | 7                                           | 8                   | 9                   | ٨                                 | В                              | с                   | D                              | E          | F                   |
|--------------------|-------------------|-------------------------------|----------------------------------------------|--------------------------------|------------------------------------------------|--------------------------------------------------------|---------------------------------------------------------|------------------------------------|---------------------------------------------|---------------------|---------------------|-----------------------------------|--------------------------------|---------------------|--------------------------------|------------|---------------------|
|                    | 0                 | 6,5<br>DEC<br>R1              | 6,5<br>DEC<br>IR1                            | 6,5<br>ADD<br>11,12            | 6, 5<br><b>ADD</b><br>r1, Ir2                  | 10, 5<br>ADD<br>R <sub>2</sub> , R <sub>1</sub>        | 10, 5<br>ADD<br>IR <sub>2</sub> , R <sub>1</sub>        | 10, 5<br><b>ADD</b><br>R1, IM      | 10, 5<br><b>ADD</b><br>IR <sub>1</sub> , IM | 6,5<br>LD<br>r1, R2 | 6,5<br>LD<br>r2, R1 | 12·10,5<br>DJNZ<br>r1, RA         | 12/10,0<br><b>JR</b><br>cc, RA | 6,5<br>LD<br>r1, IM | 12/10,0<br><b>JP</b><br>cc, DA | 6,5<br>INC |                     |
|                    | 1                 | 6, 5<br>RLC<br>R1             | 6,5<br>RLC<br>IR1                            | 6, 5<br>ADC<br>11, 12          | 6, 5<br>ADC<br>r1, Ir2                         | 10, 5<br><b>ADC</b><br>R <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>ADC</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10, 5<br>ADC<br>R1, IM             | 10, 5<br><b>ADC</b><br>IR <sub>1</sub> , IM |                     |                     |                                   |                                |                     |                                |            |                     |
|                    | 2                 | 6, 5<br>INC<br>R1             | 6,5<br>INC<br>IR1                            | 6,5<br>SUB<br>11,12            | 6, 5<br><b>SUB</b><br>r1, Ir2                  | 10, 5<br><b>SUB</b><br>R <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>SUB</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10, 5<br>SUB<br>R1, IM             | 10, 5<br><b>SUB</b><br>IR <sub>1</sub> , IM |                     |                     |                                   |                                |                     |                                |            |                     |
|                    | 3                 | 8,0<br>JP<br>IRR1             | 6, 1<br>SRP<br>IM                            | 6,5<br>SBC<br>11,12            | 6,5<br><b>SBC</b><br>r1, Ir2                   | 10, 5<br><b>SBC</b><br>R <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>SBC</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>SBC</b><br>R1, IM      | 10, 5<br><b>SBC</b><br>IR <sub>1</sub> , IM |                     |                     |                                   |                                |                     |                                |            |                     |
|                    | 4                 | 8,5<br>DA<br>R1               | 8,5<br>DA<br>IR1                             | 6, 5<br>OR<br>11, 12           | 6,5<br>OR<br>1, Ir2                            | 10, 5<br>OR<br>R <sub>2</sub> , R <sub>1</sub>         | 10, 5<br>OR<br>IR <sub>2</sub> , R <sub>1</sub>         | 10, 5<br>OR<br>R1, IM              | 10, 5<br>OR<br>IR 1, IM                     |                     |                     |                                   |                                |                     |                                |            |                     |
|                    | 5                 | 10,5<br>POP<br>R1             | 10,5<br>POP<br>IR1                           | 6,5<br>AND<br>11,12            | 6,5<br>AND<br>r1,Ir2                           | 10, 5<br>AND<br>R <sub>2</sub> , R <sub>1</sub>        | 10, 5<br><b>AND</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10, 5<br>AND<br>R1, IM             | 10, 5<br>AND<br>IR 1, IM                    |                     |                     |                                   |                                |                     |                                |            |                     |
| (Hex)              | 6                 | 6,5<br>COM<br>R1<br>10/12,1   | 6,5<br>COM<br>IR1<br>12/14,1                 | 6,5<br>TCM<br>11,12            | 6,5<br>TCM<br>r1, Ir2                          | 10, 5<br>TCM<br>R <sub>2</sub> , R <sub>1</sub>        | 10,5<br>TCM<br>IR <sub>2</sub> , R <sub>1</sub>         | 10,5<br>TCM<br>R1,IM               | 10,5<br>TCM<br>IR1,IM                       |                     |                     |                                   |                                |                     |                                |            |                     |
| Upper Nibble (Hex) | 7                 | 10/12,1<br>PUSH<br>R2<br>10,5 | 12/14, 1<br>PUSH<br>IR <sub>2</sub><br>10, 5 | 6,5<br>TM<br>11,12             | 6,5<br>TM<br>r1, Ir2<br>18,0                   | 10, 5<br><b>TM</b><br>R <sub>2</sub> , R <sub>1</sub>  | 10, 5<br>TM<br>IR <sub>2</sub> , R <sub>1</sub>         | 10, 5<br>TM<br>R1, IM              | 10,5<br><b>TM</b><br>IR <sub>1</sub> , IM   |                     |                     |                                   |                                |                     |                                |            |                     |
| Upper              | 8                 | DECW<br>RR1<br>6,5            | DECW<br>IR1<br>6,5                           | LDE<br>12,0<br>1, ITT2<br>12,0 | 18,0<br>LDEI<br>Ir1, Irr2<br>18,0              |                                                        |                                                         |                                    |                                             |                     |                     |                                   |                                |                     |                                |            | 6, 1<br>DI          |
|                    | 9                 | RL<br>R1<br>10.5              | RL<br>IR1<br>10,5                            | LDE<br>r2, Irr1<br>6, 5        | LDEI<br>Ir2, Irr1<br>6, 5                      | 10.5                                                   | 10.5                                                    | 10.5                               | 10.5                                        |                     |                     |                                   |                                |                     |                                |            | 6, 1<br>EI          |
|                    | A                 | INCW<br>RR1<br>6,5            | INCW<br>IR1<br>6,5                           | CP<br>1,12<br>6,5              | CP<br>r1, Ir2<br>6, 5                          | CP<br>R <sub>2</sub> , R <sub>1</sub><br>10, 5         | CP<br>IR <sub>2</sub> , R <sub>1</sub><br>10, 5         | CP<br>R <sub>1</sub> , IM<br>10, 5 | CP<br>IR1, IM<br>10, 5                      |                     |                     |                                   |                                |                     |                                |            | 14,0<br>RET         |
|                    | В                 | CLR<br>R1<br>6,5              | CLR<br>IR1<br>6,5                            | XOR<br>11, 12                  | XOR<br>r1, Ir2<br>18, 0                        | <b>XOR</b><br>R <sub>2</sub> , R <sub>1</sub>          | XOR<br>IR <sub>2</sub> , R <sub>1</sub>                 | XOR<br>R1, IM                      | XOR<br>IR1, IM<br>10, 5                     |                     |                     |                                   |                                |                     |                                |            | 16,0<br>IRET<br>6,5 |
|                    | с                 | RRC<br>R1<br>6,5              | RRC<br>IR 1<br>6, 5                          | LDC<br>r1, Irr2<br>12, 0       | LDCI<br>Ir1, Irr2<br>18, 0                     | 20,0                                                   |                                                         | 20,0                               | LD<br>r1, x, R2<br>10, 5                    |                     |                     |                                   |                                |                     |                                |            | 6, 5                |
|                    | D                 | SRA<br>R1<br>6, 5             | SRA<br>IR1<br>6,5                            | LDC<br>r2, Irr1                | LDCI<br>Ir2, Irr1<br>6, 5                      | CALL*<br>IRR 1<br>10, 5                                | 10,5                                                    | CALL<br>DA<br>10,5                 | LD<br>r2, x, R1<br>10, 5                    |                     |                     |                                   |                                |                     |                                |            | 6,5<br>6,5          |
|                    | E                 | RR<br>R1<br>6,7               | RR<br>IR1<br>6,7                             |                                | LD<br>11, Ir2<br>6, 5                          | LD<br>R <sub>2</sub> , R <sub>1</sub>                  | LD<br>IR <sub>2</sub> , R <sub>1</sub><br>10, 5         | LD<br>R <sub>1</sub> , IM          | LD<br>IR1, IM                               |                     |                     |                                   |                                |                     |                                |            | 6,0                 |
|                    | F                 | SWAP<br>R1                    | SWAP<br>IR1                                  | L                              | LD<br>Ir1, r2                                  |                                                        | LD<br>R <sub>2</sub> , IR <sub>1</sub>                  |                                    |                                             |                     | •                   | +                                 | •                              | •                   | •                              | +          | NOP                 |
|                    | es per<br>ruction | n                             |                                              | 2                              | Lower                                          |                                                        |                                                         | 3                                  |                                             |                     |                     | 2                                 |                                |                     | 3                              |            | l                   |
|                    |                   |                               |                                              |                                | Opcod<br>Nibble                                | e<br>;                                                 |                                                         |                                    |                                             |                     |                     |                                   |                                |                     |                                |            |                     |
|                    |                   |                               | C                                            | cution<br>Cycles               | 4                                              | Pip<br>Cyc                                             | eline<br>:les                                           |                                    |                                             |                     |                     | Legend:<br>R = 8-Bit<br>r = 4-Bit | Address<br>Address             |                     |                                |            |                     |
|                    |                   |                               | Upper<br>Opcode -<br>Nibble                  | → A                            | 10, 5<br>CP<br>R <sub>2</sub> , R <sub>1</sub> | - M                                                    | nemonic                                                 |                                    |                                             |                     |                     | R: or r: =<br>R2 or r2 =          |                                |                     |                                |            |                     |

Sequence: Opcode, First Operand, Second Operand

Note: The blank areas are not defined.

\*2-byte instruction; fetch cycle appears as a 3-byte instruction.

First Operand Second Operand

# Instruction Summary

| Instruction                                                                         | Addr             | Mode | Opcode<br>Byte        | Flags Affected |     |     | cted | Instruction                                                                               | Addr              | Mode                | Opcode               | Fla | gs A | lifected |
|-------------------------------------------------------------------------------------|------------------|------|-----------------------|----------------|-----|-----|------|-------------------------------------------------------------------------------------------|-------------------|---------------------|----------------------|-----|------|----------|
| and Operation                                                                       | dst              | src  | (Hex)                 | CZ             | zs  | V I | DН   | and Operation                                                                             | dst               | src                 | Byte<br>(Hex)        | C   | S    | VDH      |
| ADC dst,src<br>dst - dst + src + C                                                  | (Not             | e l) | 1                     | * *            | * * | *   | 0 *  | <b>LD</b> dst,src<br>dst ← src                                                            | r<br>r            | IM<br>R             | rC<br>r8             |     |      |          |
| <b>ADD</b> dst,src<br>dst ← dst + src                                               | (Not             | e l) | 0□                    | * 1            | * * | *   | 0 *  |                                                                                           | R<br>r            | r<br>X              | r9<br>r=0-F<br>C7    |     |      |          |
| <b>AND</b> dst,src<br>dst ← dst AND src                                             | (Not             | el)  | 5□                    | - 1            | * * | 0   |      |                                                                                           | X<br>r<br>Ir      | r<br>Ir<br>r        | D7<br>E3<br>F3       |     |      |          |
| <b>CALL</b> dst<br>SP $\leftarrow$ SP - 2<br>@SP $\leftarrow$ PC; PC $\leftarrow$ d | DA<br>IRR<br>dst |      | D6<br>D4              |                |     | -   |      |                                                                                           | R<br>R<br>R<br>IR | R<br>IR<br>IM<br>IM | E4<br>E5<br>E6<br>E7 |     |      |          |
| CCF<br>C - NOT C                                                                    |                  |      | EF                    | * -            |     |     | -    |                                                                                           | IR                | R                   | F5                   |     |      |          |
| <b>CLR</b> dst<br>dst ← 0                                                           | R<br>IR          |      | B0<br>B1              |                |     | -   |      | LDC dst,src<br>dst - src                                                                  | r<br>Irr          | Irr<br>r            | C2<br>D2             |     |      |          |
| <b>COM</b> dst<br>dst ← NOT dst                                                     | R<br>IR          |      | 60<br>61              | - ,            | * * | 0   |      | <b>LDCI</b> dst,src<br>dst $\leftarrow$ src<br>r $\leftarrow$ r + 1; rr $\leftarrow$ rr - | Ir<br>Irr<br>⊦l   | Irr<br>Ir           | C3<br>D3             |     |      |          |
| CP dst,src<br>dst - src                                                             | (Not             | e 1) | Α□                    | * 1            | * * | *   |      | <b>LDE</b> dst,src<br>dst ← src                                                           | r<br>Irr          | Irr<br>r            | 82<br>92             |     |      |          |
| <b>DA</b> dst<br>dst ← DA dst                                                       | R<br>IR          |      | 40<br>41              | * 1            | * * | х   |      | LDEI dst,src<br>dst – src                                                                 | Ir<br>Ir<br>Irr   | Irr<br>Ir           | 83<br>93             |     |      |          |
| <b>DEC</b> dst<br>dst ← dst - 1                                                     | R<br>IR          |      | 00<br>01              | - 1            | * * | *   |      | $\frac{r \leftarrow r + l; rr \leftarrow rr}{NOP}$                                        |                   |                     |                      |     |      |          |
| <b>DECW</b> dst<br>dst - dst - 1                                                    | RR<br>IR         |      | 80<br>81              | - ,            | * * | *   |      | OR dst,src<br>dst – dst OR src                                                            | (No               | te l)               | 4                    | - 1 | • •  | 0        |
| <b>DI</b><br>IMR (7) ← 0                                                            |                  |      | 8F                    |                |     |     |      | POP dst<br>dst ← @ SP                                                                     | R<br>IR           |                     | 50<br>51             |     |      |          |
| <b>DJNZ</b> r,dst<br>$r \leftarrow r - 1$                                           | RA               |      | rA = 0-F              |                |     |     |      | $\frac{SP \leftarrow SP + 1}{PUSH \text{ src}}$                                           |                   | R                   | 70                   |     |      |          |
| if r ≠ 0<br>PC ← PC + dst<br>Range: +127, -128                                      | 3                |      |                       |                |     |     |      | $\frac{SP \leftarrow SP - 1; @ SP}{RCF}$                                                  | - src             | IR                  | 71<br>71<br>CF       | 0 - |      |          |
| <b>EI</b><br>IMR (7) + 1                                                            | •<br>•••••••     |      | 9F                    |                |     | -   |      | C - 0                                                                                     |                   |                     |                      |     |      |          |
| INC dst                                                                             | r                |      | rE                    | -              | * * | *   |      | <b>RET</b><br>PC ← @ SP; SP ← S                                                           |                   |                     | AF                   |     |      |          |
| dst ← dst + 1                                                                       | R<br>IR          |      | r=0-F<br>20<br>21     |                |     |     |      | RL dst                                                                                    | R<br>IR           |                     | 90<br>91             | *   | * *  | *        |
| INCW dst<br>dst – dst + 1                                                           | RR<br>IR         |      | A0<br>A1              | -              | * * | *   |      | RLC dst                                                                                   | R<br>IR           |                     | 10<br>11             | *   | • •  | *        |
| IRET                                                                                | ·····            |      | BF                    | *              | * * | *   | * *  | RR dst                                                                                    | R<br>R            |                     | E0<br>E1             | *   | * *  | *        |
| $FLAGS \leftarrow @SP; SI$<br>$PC \leftarrow @SP; SP \leftarrow S$                  | SP + 2;          |      | 7) - 1                |                |     |     |      | RRC dst                                                                                   | ⊢ R<br>IR         |                     | C0<br>C1             | * • | • ÷  | *        |
| JP cc,dst<br>if cc is true<br>PC ← dst                                              | DĂ<br>IRR        |      | cD<br>c=0-F<br>30     |                |     | -   |      | <b>SBC</b> dst,src<br>dst ← dst - src - C                                                 | (Not              | el)                 | 3□                   | * • | • •  | * 1 *    |
| JR cc,dst<br>if cc is true,                                                         | RĂ               |      | cB<br>c=0-F           |                |     | -   |      | <b>SCF</b><br>C - 1                                                                       |                   |                     | DF                   | 1 - |      |          |
| $PC \leftarrow PC + dst$<br>Range: +127128                                          |                  |      | ∪ <b>U</b> - <b>f</b> |                |     |     |      | SRA dst                                                                                   | P R<br>IR         |                     | D0<br>D1             | * • | • •  | 0        |



| Instruction                             | Äddr | Mode | Opcode        | Flags Affected |   |   |   |   |   |  |  |
|-----------------------------------------|------|------|---------------|----------------|---|---|---|---|---|--|--|
| and Operation                           | dst  | src  | Byte<br>(Hex) | С              | Z | S | V | D | Н |  |  |
| <b>SRP</b> src<br>RP - src              |      | Im   | 31            | -              | - | - |   |   | - |  |  |
| <b>SUB</b> dst,src<br>dst ← dst - src   | (Not | el)  | 2□            | *              | * | * | * | 1 | * |  |  |
| SWAP dst                                | IR R |      | FO<br>Fl      | Х              | * | * | X | - | - |  |  |
| TCM dst,src<br>(NOT dst) AND src        | (Not | e 1) | 6[]           |                | * | * | 0 | - | - |  |  |
| <b>TM</b> dst,src<br>dst AND src        | (Not | el)  | 7             | -              | * | * | 0 |   | - |  |  |
| <b>XOR</b> dst,src<br>dst ← dst XOR src | (Not | el)  | В□            | -              | * | * | 0 | - | - |  |  |

# Instruction Summary (Continued)

#### Note 1

These instructions have an identical set of addressing modes, which are encoded for brevity. The first opcode nibble is found in the instruction set table above. The second nibble is expressed symbolically by a L<sup>+</sup> in this table, and its value is found in the following table to the left of the applicable addressing mode pair.

For example, to determine the opcode of an ADC instruction using the addressing modes r (destination) and Ir (source) is 13.

| Addr  | Mode | Lower         |  |
|-------|------|---------------|--|
| dst   | src  | Opcode Nibble |  |
| <br>r | r    | <u>[2]</u>    |  |
| r     | Ir   | <u>(3)</u>    |  |
| R     | R    | <u>[4]</u>    |  |
| R     | IR   | 5             |  |
| R     | IM   | 6             |  |
| IR    | IM   | Ī             |  |

### Registers









# R249 IPR Interrupt Priority Register







#### R254 MIC Master CPU Interrupt Control Register UPC register address (Hex): FE





















Figure 17. UPC Counter/Timer Registers

PRESCALER MODULO (RANGE: 1-64 DECIMAL 01-00 HEX)



| Control Register                                            | D7 | D <sub>6</sub> | $D_5$ | D4      | $D_3$ | D <sub>2</sub> | Dl | D <sub>0</sub> | Comments                                                                                                                                                                                              |
|-------------------------------------------------------------|----|----------------|-------|---------|-------|----------------|----|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00 <sub>H</sub><br>Data Transfer Control Register           | Х  | Х              | Х     | Х       | 0     | 0              | 0  | 0              | Disable data transfer<br>from master CPU                                                                                                                                                              |
| 04 <sub>H</sub><br>Limit Count Register                     |    |                |       | Not De  | fined |                |    |                |                                                                                                                                                                                                       |
| 05 <sub>H</sub><br>Data Indirection Register                |    |                |       | Not De  | fined |                | _  |                |                                                                                                                                                                                                       |
| F0 <sub>H</sub><br>Interrupt Vector Register                |    |                |       | Not De  | fined |                |    |                |                                                                                                                                                                                                       |
| F1 <sub>H</sub><br>Timer Mode                               | 0  | 0              | 0     | 0       | 0     | 0              | 0  | 0              | Stops TO and T1                                                                                                                                                                                       |
| F2 <sub>H</sub><br>T0 Register                              |    |                |       | Not De  | fined |                |    |                |                                                                                                                                                                                                       |
| F3 <sub>H</sub><br>T0 Prescaler                             | х  | Х              | Х     | Х       | Х     | х              | 0  | 0              | Single-Pass mode                                                                                                                                                                                      |
| F4 <sub>H</sub><br>Il Register                              |    |                |       | Not De  | fined |                |    |                |                                                                                                                                                                                                       |
| F5 <sub>H</sub><br>T1 Prescaler                             | Х  | Х              | Х     | Х       | х     | х              | 0  | 0              | Single-Pass mode<br>External clock source                                                                                                                                                             |
| F6 <sub>H</sub><br>Port 2 Mod <b>e</b>                      | 1  | 1              | 1     | ï       | 1     | 1              | 1  | 1              | Port 2 lines defined as inputs                                                                                                                                                                        |
| F7 <sub>H</sub><br>Port 3 Mode                              | 0  | 0              | 0     | 0       | х     | 1              | 0  | 0              | Port 1, 2 open drain;<br>P3 <sub>5</sub> = INT; P3 <sub>0</sub> , P3 <sub>1</sub> , P3;<br>P3 <sub>3</sub> defined as input; P3 <sub>4</sub> ,<br>P3 <sub>6</sub> , P3 <sub>7</sub> defined as output |
| F8 <sub>H</sub><br>Port 1 Mode                              | 1  | 1              | 1     | 1       | 1     | 1              | 1  | 1              | Port 1 lines defined as<br>inputs                                                                                                                                                                     |
| <sup>79</sup> H<br>nterrupt Priority                        |    |                | ]     | Not De  | ined  |                |    |                |                                                                                                                                                                                                       |
| FA <sub>H</sub><br>Interrupt Request                        | Х  | Х              | 0     | 0       | 0     | 0              | 0  | 0              | Reset Interrupt Request                                                                                                                                                                               |
| <sup>FB</sup> H<br>nterrupt Mask                            | 0  | Х              | Х     | х       | Х     | Х              | Х  | Х              | Interrupts disabled                                                                                                                                                                                   |
| <sup>FC</sup> H<br>Flag Register                            |    |                | 1     | Not Def | ined  |                |    |                |                                                                                                                                                                                                       |
| <sup>7</sup> D <sub>H</sub><br>Register Pointer             |    |                | 1     | Not Def | ined  |                |    |                |                                                                                                                                                                                                       |
| <sup>PE</sup> H<br>Master CPU Interrupt<br>Control Register | 0  | 0              | 0     | 0       | 0     | 0              | 0  | 0              | Master CPU interrupt dis-<br>abled; wait enable when<br>write; lower chain enabled                                                                                                                    |
| FF <sub>H</sub><br>Stack Pointer                            |    |                | 1     | Not Def | ined  |                |    |                |                                                                                                                                                                                                       |

Table 4. Control Register Reset Conditions



# Absolute Maximum Rating

| Voltages on all pins (except $V_{BB})$ with respect to GND $\ldots \ldots$ -0.5 V to +7.0 V |
|---------------------------------------------------------------------------------------------|
| Operating Ambient<br>Temperature0°C to +70°C                                                |
| Storage Temperature65°C to +150°C                                                           |

Stresses greater than those listed under Absolute Maximum Ratings may cause permanent damage to the device. This is a stress rating only; operation of the device at any condition above those indicated in the operational sections of these specifications is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

# Standard Test Conditions

The characteristics below apply for the following standard test conditions, unless otherwise noted. All voltages are referenced to GND. Positive current flows into the reference pin. Standard conditions are as follows:



Figure 18. Test Load 1

- +4.75 V ≤  $V_{CC}$  ≤ +5.25 V
- $\blacksquare$  V<sub>SS</sub> = GND = 0 V
- $\bullet$  0°C  $\leq$  T<sub>A</sub>  $\leq$  +70°C



Figure 19. Test Load 2

 $0 \leq V_{\rm IN} \leq +5.25 \text{ V}$ 

Notes

1

1

| Symb            | ol Parameter             | Parameter Min Max Ur |                 |    |                            |
|-----------------|--------------------------|----------------------|-----------------|----|----------------------------|
| V <sub>CH</sub> | Clock Input High Voltage | 2.4                  | V <sub>CC</sub> | V  |                            |
| $v_{\rm CL}$    | Clock Input Low Voltage  | -0.3                 | 0.8             | V  |                            |
| $v_{\rm IH}$    | Input High Voltage       | 2.0                  | V <sub>CC</sub> | V  |                            |
| $V_{IL}$        | Input Low Voltage        | -0.3                 | 0.8             | V  |                            |
| $v_{OH}$        | Output High Voltage      | 2.4                  |                 | V  | $I_{OH} = -250 \ \mu A$    |
| VOL             | Output Low Voltage       |                      | 0.4             | v  | $I_{OL} = +2.0 \text{ mA}$ |
| $I_{IL}$        | Input Leakage            | -10                  | 10              | μĀ | $0 \le V_{IN} \le +5.25 V$ |

-10

### **DC Characteristics**

Output Leakage

V<sub>CC</sub> Supply Current

180 1. For  $A_0-A_{11}$  and  $D_0-D_7$ ,  $\overline{MDS}$ ,  $\overline{SYNC}$ ,  $\overline{MAS}$ , and  $MR/\overline{W}/IACK$  on the 64-pin versions.  $I_{OH} = 100 \ \mu A$  and  $I_{OL} = 1.0 \ mA$ .

10

μA

mÅ

I<sub>OL</sub>

ICC



| Number | Symbol                 | Parameter                                                           | Min (ns) | Max (ns) | Notes* |
|--------|------------------------|---------------------------------------------------------------------|----------|----------|--------|
| 1      | TrC                    | Clock Rise Time                                                     |          | 20       |        |
| 2      | TwCh                   | Clock High Width                                                    | 105      | 1855     |        |
| 3      | TfC                    | Clock Fall Time                                                     |          | 20       |        |
| 4      | TwCl                   | Clock Low Width                                                     | 105      | 1855     |        |
| 5      | ТрС                    | Clock Period                                                        | 250      | 2000     |        |
| 6      | TsA/D(WR) -            | — Ā/D to WR + Setup Time ————                                       |          |          |        |
| 7      | TsA/D(RD)              | Ā/D to RD ↓ Setup Time                                              | 80       |          |        |
| 8      | Th <b>A</b> /D(WR)     | $\overline{A}/D$ to $\overline{WR}$ † Hold Time                     | 30       |          |        |
| 9      | Th <b>A</b> /D(RD)     | $\overline{A}/D$ to $\overline{RD}$ ! Hold Time                     | 30       |          |        |
| 10     | TsCSf(WR)              | CS ↓ toWR ↓ SetupTime                                               | 0        |          |        |
| 11     | TsCSf(RD) —            | — CS ↓ to RD ↓ Setup Time —                                         |          |          | ·      |
| 12     | TsCSr(WR)              | $\overline{\mathrm{CS}}$ † to $\overline{\mathrm{WR}}$ ↓ Setup Time | 60       |          |        |
| 13     | TsCSr(RD)              | CS ↑ to RD ↓ Setup Time                                             | 60       |          |        |
| 14     | ThCS(WŔ)               | CS to WR ↓ Hold Time                                                | 0        |          |        |
| 15     | ThCS(RD)               | $\overline{\text{CS}}$ to $\overline{\text{RD}}$ I Hold Time        | 0        |          |        |
| 16 —   | TsDI(WR) —             | — Data in to WR I Setup Time ————                                   | 0        |          |        |
| 17     | Tw(WR)                 | WR Low Width                                                        | 390      |          |        |
| 18     | Tw(RD)                 | RD Low Width                                                        | 390      |          |        |
| 19     | ThWR(DI)               | Data in to $\overline{\mathrm{WR}}$ † Hold Time                     | 0        |          |        |
| 20     | TdRD(DI)               | Data Valid from $\overline{\mathrm{RD}}$ I Delay                    |          |          | 1      |
| 21     | ThRD(DI)               | — Data Valid to RD † Hold Time ———                                  | 0        |          |        |
| 22     | TdRD(DI <sub>Z</sub> ) | Data Bus Float Delay from $\overline{\mathrm{RD}}$ †                |          | 70       |        |
| 23     | $TdRD(DB_A)$           | RD ↓ to Read Data Active Delay                                      | 0        |          |        |
| 24     | TdWR(W)                | WR   to WAIT   Delay                                                |          | 150      |        |
| 25     | TdRD(W)                | RD ↓ to WAIT ↓ Delay                                                |          | 150      |        |
| 26     | TdDI(W)                | Data Valid to WAIT † Delay                                          | 0        |          |        |

# Master CPU Interface Timing

NOTES 1. This parameter is dependent on the state of the UPC at the time of master CPU access.

3. The timing characteristics given reference 2.0 V as High and 0.8 V as Low.

4. All output ac parameters use test load 1. \*Timings are preliminary and subject to change.

### Interrupt Acknowledge Transactions

| Numbe | r Symbol                 | Parameter                    | Min (ns) | Max (ns) | Notes* |
|-------|--------------------------|------------------------------|----------|----------|--------|
| 27    | TsACK(RD)                | INTACK ↓ to RD ↓ Setup Time  | 90       |          | 2      |
| 28    | TdRD(DI)                 | RD 1 to Vector Valid Delay   |          | 255      |        |
| 29    | ThRD(ACK)                | RD † to INTACK † Hold Time   | 0        |          |        |
| 30    | ThIEI(RD)                | IEI to RD ↓ Hold Time        | 100      |          |        |
| 31 —  | – TwRDl –                | - RD (Acknowledge) Low Width |          |          |        |
| 32    | TdIEI(IEO)               | IEI to IEO Delay             |          | 120      |        |
| 33    | TsIEI(RD)                | IEI to RD ↓ Setup Time       | 150      |          |        |
| 34    | TdACK <sub>f</sub> (IEO) | INTACK   to IEO   Delay      |          | 250      |        |
| 35    | TdACK <sub>r</sub> (IEO) | INTACK † to IEO † Delay      |          | 250      |        |

NOTES:

In case where daisy chain is not used.
 The timing characteristics given reference 2.0 V as High and 0.8 V as Low.

All output ac parameters use test load 1.
 \*Timings are preliminary and subject to change.

# Master CPU Interface Timing





# Interrupt Acknowledge Timig



# Handshake Timing

| Numb | er Symbol | Parameter                                  | Min (ns) | Max (ns) | Notes*     |
|------|-----------|--------------------------------------------|----------|----------|------------|
| 1    | TsDI(DA)  | Data In Setup Time                         | 0        |          |            |
| 2    | ThDA(DI)  | Data In Hold Time                          | 230      |          |            |
| 3    | TwDA      | Data Available Width                       | 175      |          | 1,2        |
| 4    | TdDAL(RY) | Data Available Low to Ready<br>Delay Time  | 20<br>0  | 175      | 1,2<br>2,3 |
| 5    | TdDAH(RY) | Data Available High to Ready<br>Delay Time | 0        | 150      | 1,2<br>2,3 |
| 6    | TdDO(DA)  | Data Out to Data Available<br>Delay Time   | 50       |          | 2          |
| 7    | TdRY(DA)  | Ready to Data Available Delay Time         | 0        | 205      | 2          |

Input Handshake.
 Test Load 1.

Output Handshake.
 \*Timings are preliminary and subject to change.

## **Reset Timing**

| Number Symbol |           | Parameter                                                                                 | Min (ns) | Max (ns) | Notes* |
|---------------|-----------|-------------------------------------------------------------------------------------------|----------|----------|--------|
| 1             | TdRDQ(WR) | Delay from RD ↑ to WR ↓ for No Reset                                                      | 40       |          |        |
| 2             | TdWRQ(RD) | Delay from ₩R ↑ to RD ↓ for No Reset                                                      | 50       |          |        |
| 3             | TwRES     | Minimum Width of $\overline{\mathrm{WR}}$ and $\overline{\mathrm{RD}}$ both Low for Reset | 250      |          | 4      |

4. Internal reset signal is ½ to 2 clock delays from external reset condition.

\*Timings are preliminary and subject to change.

# RAM Version Program Memory Timing

| Number Symbol |                 | mbol Parameter                                               |     | Max (ns) | Notes* |
|---------------|-----------------|--------------------------------------------------------------|-----|----------|--------|
| 1             | TwMAS           | Memory Address Strobe Width                                  | 60  |          | 5      |
| 2             | TdA(MAS)        | Address Valid to Memory Address Strobe † Delay               | 30  |          | 5      |
| 3             | TdMR/W<br>(MAS) | Memory Read/Write to Memory Address Strobe †<br>Delay        | 30  |          | 5      |
| 4             | TdMDS(A)        | Memory Data Strobe 1 to Address Change Delay                 | 60  |          |        |
| 5             | TdMDS<br>(MR/W) | Memory Data Strobe † to Memory Read/Write Not<br>Valid Delay | 80  |          |        |
| 6             | Tw(MDS)         | Memory Data Strobe Width (Write Case)                        | 160 |          | 6      |
| 7             | TdD0(MDS)       | Data Out Valid to Memory Data Strobe↓Delay                   | 30  |          | 5      |
| 8             | TdMDS(D0)       | Memory Data Strobe 1 to Data Out Change Delay                | 30  |          | 5      |
| 9             | Tw(MDS)         | Memory Data Strobe Width (Read Case)                         | 230 |          | 6      |
| 10            | TdMDS(DI)       | Memory Data Strobe 4 to Data In Valid Delay                  |     | 160      | 7      |
| 11            | TdMAS(DI)       | Memory Address Strobe 4 to Data In Valid Delay               |     | 280      | 7      |
| 12            | ThMDS(DI)       | Memory Data Strobe † to Data In Hold Time                    | 0   |          |        |
| 13            | TwSY            | Instruction Sync Out Width                                   | 160 |          |        |
| 14            | TdSY(MDS)       | Instruction Sync Out to Memory Data Strobe Delay             | 200 |          |        |
| 15            | TwI             | Interrupt Request via Port 3 Input Width                     | 100 |          |        |

NOTES:

 Delay times are specified for an input clock frequency of 4 MHz. When operating at a lower frequency, the increase in input clock period must be added to the specified delay time.

6. Data strobe width is specified for an input clock frequency of 4 MHz. When operating at a lower frequency, the increase in three input clock periods must be added to the specified width. Data strobe width varies according to the instruction being executed.  Address strobe and data strobe to data in valid delay times represent memory system access times and are given for a 4 MHz input frequency.

- 8. All timing references assume 2.0 V for a logic "1" and 0.8 V for a logic "0."
- 9. All output ac parameters use test load 2.
- \*Timings are preliminary and subject to change.

# Handshake Timing



Input Handshake



# Handshake Timing (Continued)



Output Handshake

# **Reset Timing**



# RAM Version Program Memory Timing





# Ordering Information

| Туре                             | Package                                                                                | Temp                                                       | Clock | Description                              |
|----------------------------------|----------------------------------------------------------------------------------------|------------------------------------------------------------|-------|------------------------------------------|
| Z8590 B1<br>B6<br>D1<br>D2<br>D6 | Plastic 40 pin<br>Plastic 40 pin<br>Ceramic 40 pin<br>Ceramic 40 pin<br>Ceramic 40 pin | 0/+70°C<br>-40/+85°C<br>0/+70°C<br>-55/+125°C<br>-40/+85°C | 4MHz  | Z8590 Universal Peripheral<br>Controller |
| Z8590A B1<br>B6<br>D1<br>D6      | Plastic 40 pin<br>Plastic 40 pin<br>Ceramic 40 pin<br>Ceramic 40 pin                   | 0/+70°C<br>-40/+85°C<br>0/+70°C<br>-40/+85°C               | 6MHz  |                                          |
| Z8591 Q1                         | QUIP 64                                                                                | 0/+70°C                                                    | 4MHz  | External ROM                             |
| Z8591A Q1                        | QUIP 64                                                                                | 0/+70°C                                                    | 6MHz  | UPC                                      |
| Z8592 Q1                         | QUIP 64                                                                                | 0/+70°C                                                    | 4MHz  | External RAM                             |
| Z8592A Q1                        | QUIP 64                                                                                | 0/+70°C                                                    | 6MHz  | UPC                                      |
| Z8593 R1                         | PDP                                                                                    | 0/+70°C                                                    | 4MHz  | Piggyback EPROM                          |
| Z8593A R1                        | PDP                                                                                    | 0/+70°C                                                    | 6MHz  | UPC                                      |
| Z8594 R1                         | PDP                                                                                    | 0/+70°C                                                    | 4MHz  | Piggyback EPROM                          |
| Z8594A R1                        | PDP                                                                                    | 0/+70°C                                                    | 6MHz  | UPC                                      |



### Packages

12

0.45

48,26

\_\_\_\_\_

52,58<sup>max</sup>

«

Plastic

14.10<sup>max</sup>

15.20+16.68

P043 B





PDP







# SGS-ATES GROUP OF COMPANIES

#### INTERNATIONAL HEADQUARTERS

SGS-ATES Componenti Elettronici SpA Via C. Olivetti 2 - 20041 Agrate Brianza - Italy Tel.: 039 - 65551 Telex: 330131 - 330141

BERELUX SGS-ATES Componenti Elettronici SpA Benelux Sales Office: B- 1180 Bruxelles Winston Churchill Avenue, 122 Tel.: 02 - 3432439 Telex: 24149 B

BRAZIL Sales Office: 05413 Sao Paulo Av. Henrique Schaumann Z86 - CJ33 Tel.: 11 - 647245 Telex: 11-21650

DENMARK SGS-ATES Scandinavia AB Sales Office: 2730 Herlev Herlev Torv, 4 Tel: 02 - 948533 Telex: 35411

EASTERN EUROPE SGS-ATES Componenti Elettronici SpA Export Sales Office: 20041 Agrate Brianza - Italy Via C. Olivetti, 2 Tel.: 039 - 6555287/6555207 Telex: 330131 - 330141

FRANCE SGS-ATES France S.A. 75643 Paris Cedex 13 Résidence «Le Palatino» 17, Avenue de Choisy Tel.: 01 - 5842730 Telex: 042 - 250938

HONG KONG SGS-ATES Singapore (Pte) Ltd. 9th Floor, Block N, Kaiser Estate, Phase III, 11 Hok Yuen St., Hung Hom. Kowloon Tel:: 3-644251/5 Telex: 63906 ESGIE HX

#### ITALY

SGS-ATES Componenti Elettronici SpA Direzione Commerciale Italia 20149 Milamo Via Correggio, 1/3 Tel.: 02-4693651 Sales Offices: 40128 Bologna Via Corticella, 231 Tel.: 051-326684 00199 Roma Piazza Gondar, 11 Tel.: 06-3392484/8312777

SINGAPORE SGS-ATES Singapore (Pte) Ltd. Singapore 1231 Lorong 4 & 6 - Toa Payoh Tel: 2531411 Telex: ESGIES RS 21412

SWEDEN SGS-ATES Scandinavia AB 19500 Märsta Bristagatan 16, Tel.: 0760 - 40120 Telex: 042 - 10932

SWITZERLAND SGS-ATES AG Swiss Sales Offices **6340 Bacr** Oberneuhofstrasse, 2 Tel.: 042 - 315955 Telex: 864915 **1218 Grand-Saconnex** (Geneve)

Chemin François-Lehmann 22 Tel.: 022 - 986462/3 Telex: 28895 UNITED KINGDOM

SGS-ATES (United Kingdom) Ltd **Aylesbury, Bucks** Planar House, Walton Street Tel.: 0296 - 5977 Telex: 041 - 83245

U.S.A. SGS-ATES Semiconductor Corporation Phoenix, AZ 85022 1000 East Bell Road Tel.: (602) 867-6100 Telex: SGSPH UR 249976 Sales Offices: Austin, TX 78757 7113 Burnet Road Suite 201 Tel.: (512) 458-9182 Dallas, TX 75248 16970, Dallas North Parkway Suite 702 Tel.: (214) 733-1515 Telex: SGS-ATES DAL 79-5509 Hauppauge, NY 11788 330 Motor Parkway Suite 100 Tel.: (516) 453-1050 Indianapolis, IND 46141 2346 S. Lynhurst Drive Suite E-207 Tel.: (317) 241-1116 Santa Clara, CA 95051 2700 Augustine Drive Suite 209 Tel.: (408) 727-3404 Telex: SGS-ATES SNTA 34-6402 Schaunburg, IL 60196 600 North Meacham Road Tel.: (312) 490-1890 Telex: SGS CGP DSP 28-2547 Waltham, MA 02154 240 Bear Hill Road Tel.: (617) 890-6688 Telex: SGS-ATES WHA 92-3495 Woodland Hills, CA 91367 6355 Topanga Canyon Boulevard Suite 220 Tel.: (213) 716-6600 Telex: SGS-WDHL 18-2863

WEST GERMANY SGS-ATES Deutschland Halbleiter Bauelemente GmbH 8018 Grafing bei München Haidling, 17 Tel.: 08092-690 Telex: 05 27378 Sales Offices:

**3012 Langenhagen** Hubertusstrasse, 7 Tel.: 0511 - 772075/7 Telex: 09 23195

8000 München 90 Tegernseer Landstr., 146 Tel.: 089 - 6925100 Telex: 05 215784

**8500 Nürnberg 30** Ostendstr., 204 Tel.: 0911 - 572977/78/79 Telex: 0626243

**7000 Stuttgart 80** Kalifenweg, 45 Tel.: 0711 - 713091/2 Telex: 07 255545

Copyrig 1979, 1980, 1981 by Zilog Inc. All rights reserved. No part of this publication may be reproduces, stored in a retrieval system, or transmitted in any form or by any means, electronic, mechanical, photocopying, recording or otherwise, without the prior written permission of Zilog. The information contained herein is published by SGS-ATES and subject to change without notice. SGS-ATES assumes no responsibility for the use of circuitry embolied in the product. No other circuit patent licences are implied.

### SGS-ATES GROUP OF COMPANIES

Italy - France - Germany - Malta - Malaysia - Singapore - Sweden - Switzerland - United Kingdom - U.S.A.

© SGS-ATES Componenti Elettronici SpA 1983 - Printed in Italy TM Z-BUS, Z8 and Z8000 are Trademarks of Zilog Inc.

ORDER CODE: DAZ8500DB/1